home *** CD-ROM | disk | FTP | other *** search
MacBinary | 1989-05-30 | 14.8 KB | [TEXT/KAHL] |
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: MacBinary
(archive/macBinary).
You can browse this item here: Simulate.c
Confidence | Program | Detection | Match Type | Support
|
---|
66%
| dexvert
| Compact Compressed (Unix) (archive/compact)
| ext
| Supported |
10%
| dexvert
| MacBinary (archive/macBinary)
| fallback
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| MacBinary II, Tue May 30 11:45:05 1989, modified Tue May 30 11:45:05 1989, creator Think C, type ASCII, 14547 bytes "Simulate.c" , at 0x3953 348 bytes resource
| default (weak)
| |
99%
| file
| data
| default
| |
74%
| TrID
| Macintosh plain text (MacBinary)
| default
| |
25%
| TrID
| MacBinary 2
| default (weak)
| |
100%
| siegfried
| fmt/1762 MacBinary (II)
| default
| |
100%
| lsar
| MacBinary
| default
|
|
id metadata |
---|
key | value |
---|
macFileType | [TEXT] |
macFileCreator | [KAHL] |
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 0a 53 69 6d 75 6c 61 | 74 65 2e 63 00 00 00 00 |..Simula|te.c....|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4b 41 48 | 4c 00 00 00 00 00 00 00 |.TEXTKAH|L.......|
|00000050| 00 00 00 00 00 38 d3 00 | 00 01 5c a0 a8 67 81 a0 |.....8..|..\..g..|
|00000060| a8 67 81 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.g......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 e7 79 00 00 |........|.....y..|
|00000080| 2f 2a 09 42 61 63 74 65 | 72 69 61 20 73 69 6d 75 |/*.Bacte|ria simu|
|00000090| 6c 61 74 69 6f 6e 20 70 | 72 6f 67 72 61 6d 2e 20 |lation p|rogram. |
|000000a0| 53 63 69 65 6e 74 69 66 | 69 63 20 41 6d 65 72 69 |Scientif|ic Ameri|
|000000b0| 63 61 6e 2c 20 6d 61 79 | 20 31 39 38 39 20 2a 2f |can, may| 1989 */|
|000000c0| 0d 2f 2a 20 57 72 69 74 | 74 65 6e 20 62 79 20 4a |./* Writ|ten by J|
|000000d0| 75 72 6a 65 6e 20 4e 2e | 45 2e 20 42 6f 73 20 2a |urjen N.|E. Bos *|
|000000e0| 2f 0d 2f 2a 20 43 6f 6d | 70 69 6c 65 20 74 68 69 |/./* Com|pile thi|
|000000f0| 73 20 66 69 6c 65 20 77 | 69 74 68 20 54 48 49 4e |s file w|ith THIN|
|00000100| 4b 20 43 20 33 2e 30 2c | 20 4d 61 63 48 65 61 64 |K C 3.0,| MacHead|
|00000110| 65 72 73 20 6f 6e 20 2a | 2f 0d 2f 2a 20 4c 69 6e |ers on *|/./* Lin|
|00000120| 6b 20 69 74 20 77 69 74 | 68 20 54 72 61 6e 73 53 |k it wit|h TransS|
|00000130| 6b 65 6c 2e 63 2c 20 4d | 61 63 54 72 61 70 73 20 |kel.c, M|acTraps |
|00000140| 61 6e 64 20 61 64 64 20 | 74 68 65 20 72 65 73 6f |and add |the reso|
|00000150| 75 72 63 65 73 20 6f 66 | 20 42 75 67 73 20 50 72 |urces of| Bugs Pr|
|00000160| 6f 6a 65 63 74 2e 72 73 | 72 63 20 2a 2f 0d 2f 2a |oject.rs|rc */./*|
|00000170| 20 4f 66 20 63 6f 75 72 | 73 65 2c 20 70 6f 72 74 | Of cour|se, port|
|00000180| 69 6f 6e 73 20 a9 54 48 | 49 4e 4b 20 74 65 63 68 |ions .TH|INK tech|
|00000190| 6e 6f 6c 6f 67 69 65 73 | 2c 20 69 6e 63 2e 20 2a |nologies|, inc. *|
|000001a0| 2f 0d 0d 23 64 65 66 69 | 6e 65 20 6e 69 6c 20 28 |/..#defi|ne nil (|
|000001b0| 76 6f 69 64 20 2a 29 30 | 0d 23 64 65 66 69 6e 65 |void *)0|.#define|
|000001c0| 20 46 72 6f 6e 74 4d 6f | 73 74 20 2d 31 4c 0d 0d | FrontMo|st -1L..|
|000001d0| 23 64 65 66 69 6e 65 20 | 46 69 65 6c 64 57 69 64 |#define |FieldWid|
|000001e0| 74 68 20 35 30 37 09 09 | 2f 2a 20 77 69 64 74 68 |th 507..|/* width|
|000001f0| 20 6f 66 20 77 69 6e 64 | 6f 77 20 2a 2f 0d 23 64 | of wind|ow */.#d|
|00000200| 65 66 69 6e 65 20 46 69 | 65 6c 64 48 65 69 67 68 |efine Fi|eldHeigh|
|00000210| 74 20 32 39 39 09 09 2f | 2a 20 68 65 69 67 68 74 |t 299../|* height|
|00000220| 20 6f 66 20 77 69 6e 64 | 6f 77 20 2a 2f 0d 23 64 | of wind|ow */.#d|
|00000230| 65 66 69 6e 65 20 4d 61 | 78 42 75 67 73 20 31 35 |efine Ma|xBugs 15|
|00000240| 30 09 09 2f 2a 20 6d 61 | 78 69 6d 75 6d 20 6e 75 |0../* ma|ximum nu|
|00000250| 6d 62 65 72 20 6f 66 20 | 62 75 67 73 20 61 6c 6c |mber of |bugs all|
|00000260| 6f 77 65 64 20 2a 2f 0d | 23 64 65 66 69 6e 65 20 |owed */.|#define |
|00000270| 48 65 61 6c 74 68 50 65 | 72 42 61 63 74 20 34 30 |HealthPe|rBact 40|
|00000280| 09 09 2f 2a 20 6e 75 6d | 62 65 72 20 6f 66 20 6d |../* num|ber of m|
|00000290| 6f 76 65 73 20 74 6f 20 | 6c 69 76 65 20 66 72 6f |oves to |live fro|
|000002a0| 6d 20 61 6e 20 65 61 74 | 65 6e 20 62 61 63 74 65 |m an eat|en bacte|
|000002b0| 72 69 61 20 2a 2f 0d 23 | 64 65 66 69 6e 65 20 4d |ria */.#|define M|
|000002c0| 61 78 48 65 61 6c 74 68 | 20 31 35 30 30 09 09 2f |axHealth| 1500../|
|000002d0| 2a 20 6d 61 78 69 6d 75 | 6d 20 68 65 61 6c 74 68 |* maximu|m health|
|000002e0| 20 2a 2f 0d 23 64 65 66 | 69 6e 65 20 53 74 72 6f | */.#def|ine Stro|
|000002f0| 6e 67 48 65 61 6c 74 68 | 20 31 30 30 30 09 2f 2a |ngHealth| 1000./*|
|00000300| 20 68 65 61 6c 74 68 20 | 74 6f 20 62 65 20 73 74 | health |to be st|
|00000310| 72 6f 6e 67 20 65 6e 6f | 75 67 68 20 66 6f 72 20 |rong eno|ugh for |
|00000320| 63 68 69 6c 64 72 65 6e | 20 2a 2f 0d 23 64 65 66 |children| */.#def|
|00000330| 69 6e 65 20 53 70 6c 69 | 74 41 67 65 20 38 30 30 |ine Spli|tAge 800|
|00000340| 2f 32 09 09 2f 2a 20 61 | 67 65 20 74 6f 20 62 65 |/2../* a|ge to be|
|00000350| 20 6f 6c 64 20 65 6e 6f | 75 67 68 20 66 6f 72 20 | old eno|ugh for |
|00000360| 63 68 69 6c 64 72 65 6e | 20 2a 2f 0d 23 64 65 66 |children| */.#def|
|00000370| 69 6e 65 20 4d 61 78 41 | 67 65 20 31 32 30 30 2f |ine MaxA|ge 1200/|
|00000380| 32 09 09 2f 2a 20 6d 61 | 78 69 6d 75 6d 20 64 69 |2../* ma|ximum di|
|00000390| 73 70 6c 61 79 61 62 6c | 65 20 61 67 65 2e 20 20 |splayabl|e age. |
|000003a0| 56 61 6c 75 65 20 6d 61 | 6b 65 73 20 6e 69 63 65 |Value ma|kes nice|
|000003b0| 20 70 69 63 74 75 72 65 | 20 2a 2f 0d 23 64 65 66 | picture| */.#def|
|000003c0| 69 6e 65 20 49 6e 69 74 | 42 75 67 73 20 31 30 09 |ine Init|Bugs 10.|
|000003d0| 09 09 2f 2a 20 69 6e 69 | 74 69 61 6c 20 6e 75 6d |../* ini|tial num|
|000003e0| 62 65 72 20 6f 66 20 62 | 75 67 73 20 2a 2f 0d 23 |ber of b|ugs */.#|
|000003f0| 64 65 66 69 6e 65 20 49 | 6e 69 74 48 65 61 6c 74 |define I|nitHealt|
|00000400| 68 20 35 30 30 09 09 2f | 2a 20 69 6e 69 74 69 61 |h 500../|* initia|
|00000410| 6c 20 68 65 61 6c 74 68 | 20 6f 66 20 66 69 72 73 |l health| of firs|
|00000420| 74 20 62 75 67 73 20 2a | 2f 0d 23 64 65 66 69 6e |t bugs *|/.#defin|
|00000430| 65 20 44 69 65 54 69 6d | 65 20 35 30 09 09 09 2f |e DieTim|e 50.../|
|00000440| 2a 20 64 69 65 20 64 65 | 6c 61 79 20 2a 2f 0d 23 |* die de|lay */.#|
|00000450| 64 65 66 69 6e 65 20 49 | 6e 69 74 42 61 63 74 20 |define I|nitBact |
|00000460| 31 30 30 30 09 09 2f 2a | 20 69 6e 69 74 69 61 6c |1000../*| initial|
|00000470| 20 6e 75 6d 62 65 72 20 | 6f 66 20 62 61 63 74 65 | number |of bacte|
|00000480| 72 69 61 20 2a 2f 0d 23 | 64 65 66 69 6e 65 20 49 |ria */.#|define I|
|00000490| 6e 69 74 4d 69 6e 44 69 | 73 74 20 35 30 2a 35 30 |nitMinDi|st 50*50|
|000004a0| 09 2f 2a 20 73 71 75 61 | 72 65 20 6f 66 20 6d 69 |./* squa|re of mi|
|000004b0| 6e 69 6d 61 6c 20 64 69 | 73 74 61 6e 63 65 20 66 |nimal di|stance f|
|000004c0| 6f 72 20 63 6c 69 63 6b | 69 6e 67 20 2a 2f 0d 0d |or click|ing */..|
|000004d0| 74 79 70 65 64 65 66 20 | 73 74 72 75 63 74 20 7b |typedef |struct {|
|000004e0| 0d 09 50 6f 69 6e 74 20 | 6c 6f 63 3b 0d 09 69 6e |..Point |loc;..in|
|000004f0| 74 20 67 65 6e 65 5b 36 | 5d 2c 73 75 6d 3b 0d 09 |t gene[6|],sum;..|
|00000500| 69 6e 74 20 64 69 72 3b | 0d 09 69 6e 74 20 68 65 |int dir;|..int he|
|00000510| 61 6c 74 68 2c 61 67 65 | 3b 0d 09 7d 20 42 75 67 |alth,age|;..} Bug|
|00000520| 3b 0d 0d 76 6f 69 64 20 | 4d 65 6e 75 43 6c 6f 62 |;..void |MenuClob|
|00000530| 62 65 72 28 4d 65 6e 75 | 48 61 6e 64 6c 65 20 74 |ber(Menu|Handle t|
|00000540| 68 65 4d 65 6e 75 29 3b | 0d 76 6f 69 64 20 41 62 |heMenu);|.void Ab|
|00000550| 6f 75 74 28 76 6f 69 64 | 29 3b 0d 76 6f 69 64 20 |out(void|);.void |
|00000560| 45 64 69 74 4d 65 6e 75 | 28 69 6e 74 20 69 74 65 |EditMenu|(int ite|
|00000570| 6d 29 3b 0d 76 6f 69 64 | 20 46 69 6c 65 4d 65 6e |m);.void| FileMen|
|00000580| 75 28 76 6f 69 64 29 3b | 0d 76 6f 69 64 20 42 61 |u(void);|.void Ba|
|00000590| 63 74 4d 65 6e 75 28 69 | 6e 74 20 69 74 65 6d 29 |ctMenu(i|nt item)|
|000005a0| 3b 0d 76 6f 69 64 20 57 | 69 6e 64 6f 77 43 6c 6f |;.void W|indowClo|
|000005b0| 62 62 65 72 28 76 6f 69 | 64 29 3b 0d 76 6f 69 64 |bber(voi|d);.void|
|000005c0| 20 57 69 6e 64 6f 77 55 | 70 64 61 74 65 28 76 6f | WindowU|pdate(vo|
|000005d0| 69 64 29 3b 0d 76 6f 69 | 64 20 57 69 6e 64 6f 77 |id);.voi|d Window|
|000005e0| 41 63 74 69 76 61 74 65 | 28 42 6f 6f 6c 65 61 6e |Activate|(Boolean|
|000005f0| 20 61 63 74 69 76 65 29 | 3b 0d 76 6f 69 64 20 4d | active)|;.void M|
|00000600| 61 6b 65 50 6f 72 74 28 | 47 72 61 66 50 74 72 20 |akePort(|GrafPtr |
|00000610| 70 6f 72 74 29 3b 0d 76 | 6f 69 64 20 49 6e 69 74 |port);.v|oid Init|
|00000620| 28 76 6f 69 64 29 3b 0d | 76 6f 69 64 20 44 6f 47 |(void);.|void DoG|
|00000630| 65 6e 65 72 61 74 69 6f | 6e 28 76 6f 69 64 29 3b |eneratio|n(void);|
|00000640| 0d 76 6f 69 64 20 57 69 | 6e 64 6f 77 4d 6f 75 73 |.void Wi|ndowMous|
|00000650| 65 28 50 6f 69 6e 74 20 | 74 68 65 50 6f 69 6e 74 |e(Point |thePoint|
|00000660| 29 3b 0d 76 6f 69 64 20 | 50 75 74 42 61 63 74 65 |);.void |PutBacte|
|00000670| 72 69 61 28 76 6f 69 64 | 29 3b 0d 76 6f 69 64 20 |ria(void|);.void |
|00000680| 4d 6f 76 65 42 75 67 28 | 42 75 67 20 2a 74 68 65 |MoveBug(|Bug *the|
|00000690| 42 75 67 29 3b 0d 76 6f | 69 64 20 4b 69 6c 6c 42 |Bug);.vo|id KillB|
|000006a0| 75 67 28 42 75 67 20 2a | 74 68 65 42 75 67 29 3b |ug(Bug *|theBug);|
|000006b0| 0d 76 6f 69 64 20 53 70 | 6c 69 74 42 75 67 28 42 |.void Sp|litBug(B|
|000006c0| 75 67 20 2a 74 68 65 42 | 75 67 29 3b 0d 0d 75 6e |ug *theB|ug);..un|
|000006d0| 73 69 67 6e 65 64 20 69 | 6e 74 20 52 61 6e 64 6f |signed i|nt Rando|
|000006e0| 6d 52 61 6e 67 65 28 2f | 2a 20 75 6e 73 69 67 6e |mRange(/|* unsign|
|000006f0| 65 64 20 69 6e 74 20 74 | 6f 70 20 2a 2f 29 3b 0d |ed int t|op */);.|
|00000700| 6c 6f 6e 67 20 69 6e 74 | 20 53 51 44 69 73 74 28 |long int| SQDist(|
|00000710| 2f 2a 20 50 6f 69 6e 74 | 20 61 2c 62 20 2a 2f 29 |/* Point| a,b */)|
|00000720| 3b 0d 69 6e 74 20 53 63 | 61 6c 65 28 69 6e 74 20 |;.int Sc|ale(int |
|00000730| 61 2c 69 6e 74 20 62 2c | 69 6e 74 20 63 29 3b 0d |a,int b,|int c);.|
|00000740| 69 6e 74 20 43 6f 75 6e | 74 50 69 78 65 6c 73 28 |int Coun|tPixels(|
|00000750| 69 6e 74 20 68 2c 69 6e | 74 20 76 29 3b 0d 0d 57 |int h,in|t v);..W|
|00000760| 69 6e 64 6f 77 50 74 72 | 20 6d 79 57 69 6e 64 6f |indowPtr| myWindo|
|00000770| 77 3b 0d 65 6e 75 6d 20 | 7b 0d 09 46 3d 30 2c 52 |w;.enum |{..F=0,R|
|00000780| 2c 48 52 2c 52 56 2c 48 | 4c 2c 4c 0d 09 7d 3b 0d |,HR,RV,H|L,L..};.|
|00000790| 65 6e 75 6d 20 7b 0d 09 | 67 72 6f 77 55 6e 69 66 |enum {..|growUnif|
|000007a0| 6f 72 6d 3d 34 2c 67 72 | 6f 77 4e 6f 6e 65 2c 67 |orm=4,gr|owNone,g|
|000007b0| 72 6f 77 50 61 74 74 65 | 72 6e 2c 67 72 6f 77 47 |rowPatte|rn,growG|
|000007c0| 61 72 64 65 6e 2c 67 72 | 6f 77 43 65 6e 74 65 72 |arden,gr|owCenter|
|000007d0| 65 64 0d 09 7d 3b 0d 69 | 6e 74 20 68 6d 6f 76 65 |ed..};.i|nt hmove|
|000007e0| 5b 5d 3d 7b 32 2c 31 2c | 2d 31 2c 2d 32 2c 2d 31 |[]={2,1,|-1,-2,-1|
|000007f0| 2c 31 7d 3b 0d 69 6e 74 | 20 76 6d 6f 76 65 5b 5d |,1};.int| vmove[]|
|00000800| 3d 7b 30 2c 32 2c 32 2c | 30 2c 2d 32 2c 2d 32 7d |={0,2,2,|0,-2,-2}|
|00000810| 3b 0d 42 75 67 20 62 75 | 67 5b 4d 61 78 42 75 67 |;.Bug bu|g[MaxBug|
|00000820| 73 5d 3b 0d 69 6e 74 20 | 6e 75 6d 42 75 67 73 3d |s];.int |numBugs=|
|00000830| 49 6e 69 74 42 75 67 73 | 3b 20 09 09 2f 2a 20 6e |InitBugs|; ../* n|
|00000840| 75 6d 62 65 72 20 6f 66 | 20 62 75 67 73 20 2a 2f |umber of| bugs */|
|00000850| 0d 47 72 61 66 50 6f 72 | 74 20 62 61 63 74 50 6f |.GrafPor|t bactPo|
|00000860| 72 74 3b 0d 47 72 61 66 | 50 74 72 20 77 69 6e 64 |rt;.Graf|Ptr wind|
|00000870| 6f 77 4d 61 70 3b 0d 69 | 6e 74 20 67 72 6f 77 4d |owMap;.i|nt growM|
|00000880| 6f 64 65 3d 67 72 6f 77 | 55 6e 69 66 6f 72 6d 3b |ode=grow|Uniform;|
|00000890| 09 2f 2a 20 62 61 63 74 | 65 72 69 61 20 67 72 6f |./* bact|eria gro|
|000008a0| 77 20 6d 6f 64 65 20 2a | 2f 0d 50 6f 69 6e 74 20 |w mode *|/.Point |
|000008b0| 62 61 63 74 4c 6f 63 3d | 7b 31 30 2c 31 30 7d 3b |bactLoc=|{10,10};|
|000008c0| 09 09 2f 2a 20 6c 6f 63 | 61 74 69 6f 6e 20 66 6f |../* loc|ation fo|
|000008d0| 72 20 70 61 74 74 65 72 | 6e 20 67 72 6f 77 20 6d |r patter|n grow m|
|000008e0| 6f 64 65 20 2a 2f 0d 0d | 0d 6d 61 69 6e 28 29 0d |ode */..|.main().|
|000008f0| 7b 0d 52 65 63 74 20 52 | 3b 0d 09 53 6b 65 6c 49 |{.Rect R|;..SkelI|
|00000900| 6e 69 74 28 31 2c 6e 69 | 6c 29 3b 0d 09 53 6b 65 |nit(1,ni|l);..Ske|
|00000910| 6c 41 70 70 6c 65 28 22 | 5c 70 41 62 6f 75 74 20 |lApple("|\pAbout |
|00000920| 42 75 67 73 c9 22 2c 41 | 62 6f 75 74 29 3b 0d 09 |Bugs.",A|bout);..|
|00000930| 53 6b 65 6c 4d 65 6e 75 | 28 47 65 74 4d 65 6e 75 |SkelMenu|(GetMenu|
|00000940| 28 31 32 39 29 2c 46 69 | 6c 65 4d 65 6e 75 2c 4d |(129),Fi|leMenu,M|
|00000950| 65 6e 75 43 6c 6f 62 62 | 65 72 2c 66 61 6c 73 65 |enuClobb|er,false|
|00000960| 29 3b 0d 09 53 6b 65 6c | 4d 65 6e 75 28 47 65 74 |);..Skel|Menu(Get|
|00000970| 4d 65 6e 75 28 31 33 30 | 29 2c 45 64 69 74 4d 65 |Menu(130|),EditMe|
|00000980| 6e 75 2c 4d 65 6e 75 43 | 6c 6f 62 62 65 72 2c 66 |nu,MenuC|lobber,f|
|00000990| 61 6c 73 65 29 3b 0d 09 | 53 6b 65 6c 4d 65 6e 75 |alse);..|SkelMenu|
|000009a0| 28 47 65 74 4d 65 6e 75 | 28 31 33 31 29 2c 42 61 |(GetMenu|(131),Ba|
|000009b0| 63 74 4d 65 6e 75 2c 4d | 65 6e 75 43 6c 6f 62 62 |ctMenu,M|enuClobb|
|000009c0| 65 72 2c 74 72 75 65 29 | 3b 0d 09 09 2f 2a 20 6d |er,true)|;.../* m|
|000009d0| 61 6b 65 20 6f 75 72 20 | 77 69 6e 64 6f 77 20 2a |ake our |window *|
|000009e0| 2f 0d 09 52 3d 73 63 72 | 65 65 6e 42 69 74 73 2e |/..R=scr|eenBits.|
|000009f0| 62 6f 75 6e 64 73 3b 0d | 09 09 2f 2a 20 57 61 74 |bounds;.|../* Wat|
|00000a00| 63 68 20 74 68 69 73 3a | 20 63 65 6e 74 65 72 69 |ch this:| centeri|
|00000a10| 6e 67 20 74 68 65 20 72 | 69 67 68 74 20 77 61 79 |ng the r|ight way|
|00000a20| 21 20 2a 2f 0d 09 52 2e | 62 6f 74 74 6f 6d 3d 28 |! */..R.|bottom=(|
|00000a30| 20 52 2e 74 6f 70 3d 28 | 52 2e 74 6f 70 2b 52 2e | R.top=(|R.top+R.|
|00000a40| 62 6f 74 74 6f 6d 2b 33 | 38 2d 46 69 65 6c 64 48 |bottom+3|8-FieldH|
|00000a50| 65 69 67 68 74 29 2f 32 | 20 29 2b 46 69 65 6c 64 |eight)/2| )+Field|
|00000a60| 48 65 69 67 68 74 3b 0d | 09 52 2e 72 69 67 68 74 |Height;.|.R.right|
|00000a70| 3d 28 20 52 2e 6c 65 66 | 74 3d 28 52 2e 6c 65 66 |=( R.lef|t=(R.lef|
|00000a80| 74 2b 52 2e 72 69 67 68 | 74 2d 46 69 65 6c 64 57 |t+R.righ|t-FieldW|
|00000a90| 69 64 74 68 29 2f 32 20 | 29 2b 46 69 65 6c 64 57 |idth)/2 |)+FieldW|
|00000aa0| 69 64 74 68 3b 0d 09 6d | 79 57 69 6e 64 6f 77 3d |idth;..m|yWindow=|
|00000ab0| 4e 65 77 57 69 6e 64 6f | 77 28 6e 69 6c 2c 26 52 |NewWindo|w(nil,&R|
|00000ac0| 2c 22 5c 70 4a 75 72 6a | 65 6e d5 73 20 42 75 67 |,"\pJurj|en.s Bug|
|00000ad0| 73 22 2c 74 72 75 65 2c | 34 2c 46 72 6f 6e 74 4d |s",true,|4,FrontM|
|00000ae0| 6f 73 74 2c 66 61 6c 73 | 65 2c 30 29 3b 0d 09 53 |ost,fals|e,0);..S|
|00000af0| 6b 65 6c 57 69 6e 64 6f | 77 28 6d 79 57 69 6e 64 |kelWindo|w(myWind|
|00000b00| 6f 77 2c 0d 09 09 57 69 | 6e 64 6f 77 4d 6f 75 73 |ow,...Wi|ndowMous|
|00000b10| 65 2c 6e 69 6c 2c 57 69 | 6e 64 6f 77 55 70 64 61 |e,nil,Wi|ndowUpda|
|00000b20| 74 65 2c 57 69 6e 64 6f | 77 41 63 74 69 76 61 74 |te,Windo|wActivat|
|00000b30| 65 2c 6e 69 6c 2c 57 69 | 6e 64 6f 77 43 6c 6f 62 |e,nil,Wi|ndowClob|
|00000b40| 62 65 72 2c 44 6f 47 65 | 6e 65 72 61 74 69 6f 6e |ber,DoGe|neration|
|00000b50| 2c 66 61 6c 73 65 29 3b | 0d 09 49 6e 69 74 28 29 |,false);|..Init()|
|00000b60| 3b 0d 09 53 6b 65 6c 4d | 61 69 6e 28 29 3b 0d 09 |;..SkelM|ain();..|
|00000b70| 53 6b 65 6c 43 6c 6f 62 | 62 65 72 28 29 3b 0d 7d |SkelClob|ber();.}|
|00000b80| 0d 0d 76 6f 69 64 20 4d | 65 6e 75 43 6c 6f 62 62 |..void M|enuClobb|
|00000b90| 65 72 28 74 68 65 4d 65 | 6e 75 29 0d 4d 65 6e 75 |er(theMe|nu).Menu|
|00000ba0| 48 61 6e 64 6c 65 20 74 | 68 65 4d 65 6e 75 3b 0d |Handle t|heMenu;.|
|00000bb0| 7b 0d 09 52 65 6c 65 61 | 73 65 52 65 73 6f 75 72 |{..Relea|seResour|
|00000bc0| 63 65 28 74 68 65 4d 65 | 6e 75 29 3b 0d 7d 0d 0d |ce(theMe|nu);.}..|
|00000bd0| 76 6f 69 64 20 41 62 6f | 75 74 28 29 0d 7b 0d 09 |void Abo|ut().{..|
|00000be0| 41 6c 65 72 74 28 31 30 | 30 32 2c 6e 69 6c 29 3b |Alert(10|02,nil);|
|00000bf0| 0d 7d 0d 0d 76 6f 69 64 | 20 45 64 69 74 4d 65 6e |.}..void| EditMen|
|00000c00| 75 28 69 74 65 6d 29 0d | 69 6e 74 20 69 74 65 6d |u(item).|int item|
|00000c10| 3b 0d 7b 0d 09 53 79 73 | 74 65 6d 45 64 69 74 28 |;.{..Sys|temEdit(|
|00000c20| 69 74 65 6d 2d 31 29 3b | 0d 7d 0d 0d 76 6f 69 64 |item-1);|.}..void|
|00000c30| 20 46 69 6c 65 4d 65 6e | 75 28 29 0d 7b 0d 09 53 | FileMen|u().{..S|
|00000c40| 6b 65 6c 57 68 6f 61 28 | 29 3b 0d 7d 0d 0d 76 6f |kelWhoa(|);.}..vo|
|00000c50| 69 64 20 42 61 63 74 4d | 65 6e 75 28 69 74 65 6d |id BactM|enu(item|
|00000c60| 29 0d 69 6e 74 20 69 74 | 65 6d 3b 0d 7b 0d 72 65 |).int it|em;.{.re|
|00000c70| 67 69 73 74 65 72 20 44 | 69 61 6c 6f 67 50 74 72 |gister D|ialogPtr|
|00000c80| 20 6d 79 44 69 61 6c 6f | 67 3b 0d 69 6e 74 20 74 | myDialo|g;.int t|
|00000c90| 79 70 65 3b 0d 48 61 6e | 64 6c 65 20 69 74 65 6d |ype;.Han|dle item|
|00000ca0| 48 61 6e 64 6c 65 3b 0d | 52 65 63 74 20 62 6f 78 |Handle;.|Rect box|
|00000cb0| 3b 0d 09 69 66 28 69 74 | 65 6d 3d 3d 31 29 7b 0d |;..if(it|em==1){.|
|00000cc0| 09 09 2f 2a 20 63 68 61 | 6e 67 65 20 62 61 63 74 |../* cha|nge bact|
|00000cd0| 65 72 69 61 20 70 6f 70 | 75 6c 61 74 69 6f 6e 20 |eria pop|ulation |
|00000ce0| 2a 2f 0d 09 72 65 67 69 | 73 74 65 72 20 69 6e 74 |*/..regi|ster int|
|00000cf0| 20 70 6f 70 75 6c 61 74 | 69 6f 6e 3d 35 2c 20 61 | populat|ion=5, a|
|00000d00| 64 64 3d 30 3b 0d 09 72 | 65 67 69 73 74 65 72 20 |dd=0;..r|egister |
|00000d10| 69 6e 74 20 76 61 6c 75 | 65 3b 0d 09 09 6d 79 44 |int valu|e;...myD|
|00000d20| 69 61 6c 6f 67 3d 47 65 | 74 4e 65 77 44 69 61 6c |ialog=Ge|tNewDial|
|00000d30| 6f 67 28 31 30 30 30 2c | 6e 69 6c 2c 46 72 6f 6e |og(1000,|nil,Fron|
|00000d40| 74 4d 6f 73 74 29 3b 0d | 09 09 53 65 74 50 6f 72 |tMost);.|..SetPor|
|00000d50| 74 28 6d 79 44 69 61 6c | 6f 67 29 3b 0d 09 09 47 |t(myDial|og);...G|
|00000d60| 65 74 44 49 74 65 6d 28 | 6d 79 44 69 61 6c 6f 67 |etDItem(|myDialog|
|00000d70| 2c 31 2c 26 74 79 70 65 | 2c 26 69 74 65 6d 48 61 |,1,&type|,&itemHa|
|00000d80| 6e 64 6c 65 2c 26 62 6f | 78 29 3b 0d 09 09 50 65 |ndle,&bo|x);...Pe|
|00000d90| 6e 53 69 7a 65 28 33 2c | 33 29 3b 0d 09 09 49 6e |nSize(3,|3);...In|
|00000da0| 73 65 74 52 65 63 74 28 | 26 62 6f 78 2c 2d 34 2c |setRect(|&box,-4,|
|00000db0| 2d 34 29 3b 0d 09 09 46 | 72 61 6d 65 52 6f 75 6e |-4);...F|rameRoun|
|00000dc0| 64 52 65 63 74 28 26 62 | 6f 78 2c 31 36 2c 31 36 |dRect(&b|ox,16,16|
|00000dd0| 29 3b 0d 09 09 69 74 65 | 6d 3d 35 3b 76 61 6c 75 |);...ite|m=5;valu|
|00000de0| 65 3d 31 3b 0d 09 09 64 | 6f 20 7b 0d 09 09 09 47 |e=1;...d|o {....G|
|00000df0| 65 74 44 49 74 65 6d 28 | 6d 79 44 69 61 6c 6f 67 |etDItem(|myDialog|
|00000e00| 2c 69 74 65 6d 2c 26 74 | 79 70 65 2c 26 69 74 65 |,item,&t|ype,&ite|
|00000e10| 6d 48 61 6e 64 6c 65 2c | 26 62 6f 78 29 3b 0d 09 |mHandle,|&box);..|
|00000e20| 09 09 53 65 74 43 74 6c | 56 61 6c 75 65 28 69 74 |..SetCtl|Value(it|
|00000e30| 65 6d 48 61 6e 64 6c 65 | 2c 76 61 6c 75 65 29 3b |emHandle|,value);|
|00000e40| 0d 09 09 09 4d 6f 64 61 | 6c 44 69 61 6c 6f 67 28 |....Moda|lDialog(|
|00000e50| 6e 69 6c 2c 26 69 74 65 | 6d 29 3b 0d 09 09 09 2f |nil,&ite|m);..../|
|00000e60| 2a 20 31 3a 20 4f 4b 2c | 20 32 3a 20 63 61 6e 63 |* 1: OK,| 2: canc|
|00000e70| 65 6c 2c 20 34 3a 20 41 | 64 64 20 74 6f 20 63 75 |el, 4: A|dd to cu|
|00000e80| 72 72 65 6e 74 20 70 6f | 70 75 6c 61 74 69 6f 6e |rrent po|pulation|
|00000e90| 2c 0d 09 09 09 09 35 3a | 20 52 61 6e 64 6f 6d 2c |,.....5:| Random,|
|00000ea0| 20 36 3a 20 4e 6f 6e 65 | 2c 20 37 3a 20 50 61 74 | 6: None|, 7: Pat|
|00000eb0| 74 65 72 6e 20 2a 2f 0d | 09 09 09 69 66 28 69 74 |tern */.|...if(it|
|00000ec0| 65 6d 3d 3d 34 29 0d 09 | 09 09 09 76 61 6c 75 65 |em==4)..|...value|
|00000ed0| 3d 61 64 64 3d 31 2d 61 | 64 64 3b 0d 09 09 09 65 |=add=1-a|dd;....e|
|00000ee0| 6c 73 65 20 69 66 28 69 | 74 65 6d 3e 34 29 20 7b |lse if(i|tem>4) {|
|00000ef0| 0d 09 09 09 09 47 65 74 | 44 49 74 65 6d 28 6d 79 |.....Get|DItem(my|
|00000f00| 44 69 61 6c 6f 67 2c 70 | 6f 70 75 6c 61 74 69 6f |Dialog,p|opulatio|
|00000f10| 6e 2c 26 74 79 70 65 2c | 26 69 74 65 6d 48 61 6e |n,&type,|&itemHan|
|00000f20| 64 6c 65 2c 26 62 6f 78 | 29 3b 0d 09 09 09 09 53 |dle,&box|);.....S|
|00000f30| 65 74 43 74 6c 56 61 6c | 75 65 28 69 74 65 6d 48 |etCtlVal|ue(itemH|
|00000f40| 61 6e 64 6c 65 2c 30 29 | 3b 0d 09 09 09 09 76 61 |andle,0)|;.....va|
|00000f50| 6c 75 65 3d 70 6f 70 75 | 6c 61 74 69 6f 6e 3d 69 |lue=popu|lation=i|
|00000f60| 74 65 6d 3b 0d 09 09 09 | 7d 0d 09 09 7d 20 77 68 |tem;....|}...} wh|
|00000f70| 69 6c 65 20 28 69 74 65 | 6d 3e 32 29 3b 0d 09 09 |ile (ite|m>2);...|
|00000f80| 44 69 73 70 6f 73 44 69 | 61 6c 6f 67 28 6d 79 44 |DisposDi|alog(myD|
|00000f90| 69 61 6c 6f 67 29 3b 0d | 09 09 69 66 28 69 74 65 |ialog);.|..if(ite|
|00000fa0| 6d 3d 3d 31 29 20 7b 0d | 09 09 09 53 65 74 50 6f |m==1) {.|...SetPo|
|00000fb0| 72 74 28 26 62 61 63 74 | 50 6f 72 74 29 3b 0d 09 |rt(&bact|Port);..|
|00000fc0| 09 09 69 66 28 21 61 64 | 64 29 20 45 72 61 73 65 |..if(!ad|d) Erase|
|00000fd0| 52 65 63 74 28 26 62 61 | 63 74 50 6f 72 74 2e 70 |Rect(&ba|ctPort.p|
|00000fe0| 6f 72 74 52 65 63 74 29 | 3b 0d 09 09 09 69 66 28 |ortRect)|;....if(|
|00000ff0| 70 6f 70 75 6c 61 74 69 | 6f 6e 3d 3d 37 29 20 7b |populati|on==7) {|
|00001000| 0d 09 09 09 09 50 65 6e | 4d 6f 64 65 28 70 61 74 |.....Pen|Mode(pat|
|00001010| 4f 72 29 3b 0d 09 09 09 | 09 50 65 6e 50 61 74 28 |Or);....|.PenPat(|
|00001020| 6c 74 47 72 61 79 29 3b | 0d 09 09 09 09 50 61 69 |ltGray);|.....Pai|
|00001030| 6e 74 52 65 63 74 28 26 | 62 61 63 74 50 6f 72 74 |ntRect(&|bactPort|
|00001040| 2e 70 6f 72 74 52 65 63 | 74 29 3b 0d 09 09 09 09 |.portRec|t);.....|
|00001050| 50 65 6e 4d 6f 64 65 28 | 70 61 74 43 6f 70 79 29 |PenMode(|patCopy)|
|00001060| 3b 0d 09 09 09 09 50 65 | 6e 50 61 74 28 62 6c 61 |;.....Pe|nPat(bla|
|00001070| 63 6b 29 3b 0d 09 09 09 | 7d 0d 09 09 09 53 65 74 |ck);....|}....Set|
|00001080| 50 6f 72 74 28 77 69 6e | 64 6f 77 4d 61 70 29 3b |Port(win|dowMap);|
|00001090| 0d 09 09 09 57 69 6e 64 | 6f 77 55 70 64 61 74 65 |....Wind|owUpdate|
|000010a0| 28 29 3b 0d 09 09 09 69 | 66 28 70 6f 70 75 6c 61 |();....i|f(popula|
|000010b0| 74 69 6f 6e 3d 3d 35 29 | 20 66 6f 72 28 76 61 6c |tion==5)| for(val|
|000010c0| 75 65 3d 30 3b 76 61 6c | 75 65 3c 49 6e 69 74 42 |ue=0;val|ue<InitB|
|000010d0| 61 63 74 3b 76 61 6c 75 | 65 2b 2b 29 20 50 75 74 |act;valu|e++) Put|
|000010e0| 42 61 63 74 65 72 69 61 | 28 29 3b 0d 09 09 7d 0d |Bacteria|();...}.|
|000010f0| 09 7d 65 6c 73 65 7b 0d | 09 09 2f 2a 20 63 68 61 |.}else{.|../* cha|
|00001100| 6e 67 65 20 62 61 63 74 | 65 72 69 61 20 67 72 6f |nge bact|eria gro|
|00001110| 77 74 68 20 2a 2f 0d 09 | 72 65 67 69 73 74 65 72 |wth */..|register|
|00001120| 20 69 6e 74 20 67 72 6f | 77 74 68 3d 67 72 6f 77 | int gro|wth=grow|
|00001130| 55 6e 69 66 6f 72 6d 3b | 0d 09 09 6d 79 44 69 61 |Uniform;|...myDia|
|00001140| 6c 6f 67 3d 47 65 74 4e | 65 77 44 69 61 6c 6f 67 |log=GetN|ewDialog|
|00001150| 28 31 30 30 31 2c 6e 69 | 6c 2c 46 72 6f 6e 74 4d |(1001,ni|l,FrontM|
|00001160| 6f 73 74 29 3b 0d 09 09 | 53 65 74 50 6f 72 74 28 |ost);...|SetPort(|
|00001170| 6d 79 44 69 61 6c 6f 67 | 29 3b 0d 09 09 47 65 74 |myDialog|);...Get|
|00001180| 44 49 74 65 6d 28 6d 79 | 44 69 61 6c 6f 67 2c 31 |DItem(my|Dialog,1|
|00001190| 2c 26 74 79 70 65 2c 26 | 69 74 65 6d 48 61 6e 64 |,&type,&|itemHand|
|000011a0| 6c 65 2c 26 62 6f 78 29 | 3b 0d 09 09 50 65 6e 53 |le,&box)|;...PenS|
|000011b0| 69 7a 65 28 33 2c 33 29 | 3b 0d 09 09 49 6e 73 65 |ize(3,3)|;...Inse|
|000011c0| 74 52 65 63 74 28 26 62 | 6f 78 2c 2d 34 2c 2d 34 |tRect(&b|ox,-4,-4|
|000011d0| 29 3b 0d 09 09 46 72 61 | 6d 65 52 6f 75 6e 64 52 |);...Fra|meRoundR|
|000011e0| 65 63 74 28 26 62 6f 78 | 2c 31 36 2c 31 36 29 3b |ect(&box|,16,16);|
|000011f0| 0d 09 09 64 6f 20 7b 0d | 09 09 09 47 65 74 44 49 |...do {.|...GetDI|
|00001200| 74 65 6d 28 6d 79 44 69 | 61 6c 6f 67 2c 67 72 6f |tem(myDi|alog,gro|
|00001210| 77 74 68 2c 26 74 79 70 | 65 2c 26 69 74 65 6d 48 |wth,&typ|e,&itemH|
|00001220| 61 6e 64 6c 65 2c 26 62 | 6f 78 29 3b 0d 09 09 09 |andle,&b|ox);....|
|00001230| 53 65 74 43 74 6c 56 61 | 6c 75 65 28 69 74 65 6d |SetCtlVa|lue(item|
|00001240| 48 61 6e 64 6c 65 2c 31 | 29 3b 0d 09 09 09 4d 6f |Handle,1|);....Mo|
|00001250| 64 61 6c 44 69 61 6c 6f | 67 28 6e 69 6c 2c 26 69 |dalDialo|g(nil,&i|
|00001260| 74 65 6d 29 3b 0d 09 09 | 09 2f 2a 20 31 3a 20 4f |tem);...|./* 1: O|
|00001270| 4b 2c 20 32 3a 20 63 61 | 6e 63 65 6c 2c 20 34 3a |K, 2: ca|ncel, 4:|
|00001280| 20 71 2c 0d 09 09 09 09 | 35 3a 20 71 2c 20 36 3a | q,.....|5: q, 6:|
|00001290| 20 71 2c 20 37 3a 20 71 | 2c 20 38 3a 71 20 2a 2f | q, 7: q|, 8:q */|
|000012a0| 0d 09 09 09 69 66 28 69 | 74 65 6d 3e 33 29 20 7b |....if(i|tem>3) {|
|000012b0| 0d 09 09 09 09 47 65 74 | 44 49 74 65 6d 28 6d 79 |.....Get|DItem(my|
|000012c0| 44 69 61 6c 6f 67 2c 67 | 72 6f 77 74 68 2c 26 74 |Dialog,g|rowth,&t|
|000012d0| 79 70 65 2c 26 69 74 65 | 6d 48 61 6e 64 6c 65 2c |ype,&ite|mHandle,|
|000012e0| 26 62 6f 78 29 3b 0d 09 | 09 09 09 53 65 74 43 74 |&box);..|...SetCt|
|000012f0| 6c 56 61 6c 75 65 28 69 | 74 65 6d 48 61 6e 64 6c |lValue(i|temHandl|
|00001300| 65 2c 30 29 3b 0d 09 09 | 09 09 67 72 6f 77 74 68 |e,0);...|..growth|
|00001310| 3d 69 74 65 6d 3b 0d 09 | 09 09 7d 0d 09 09 7d 20 |=item;..|..}...} |
|00001320| 77 68 69 6c 65 20 28 69 | 74 65 6d 3e 32 29 3b 0d |while (i|tem>2);.|
|00001330| 09 09 44 69 73 70 6f 73 | 44 69 61 6c 6f 67 28 6d |..Dispos|Dialog(m|
|00001340| 79 44 69 61 6c 6f 67 29 | 3b 0d 09 09 69 66 28 69 |yDialog)|;...if(i|
|00001350| 74 65 6d 3d 3d 31 29 20 | 67 72 6f 77 4d 6f 64 65 |tem==1) |growMode|
|00001360| 3d 67 72 6f 77 74 68 3b | 0d 7d 09 7d 0d 0d 76 6f |=growth;|.}.}..vo|
|00001370| 69 64 20 57 69 6e 64 6f | 77 43 6c 6f 62 62 65 72 |id Windo|wClobber|
|00001380| 28 29 0d 7b 0d 09 44 69 | 73 70 6f 73 65 57 69 6e |().{..Di|sposeWin|
|00001390| 64 6f 77 28 6d 79 57 69 | 6e 64 6f 77 29 3b 0d 7d |dow(myWi|ndow);.}|
|000013a0| 0d 0d 76 6f 69 64 20 57 | 69 6e 64 6f 77 55 70 64 |..void W|indowUpd|
|000013b0| 61 74 65 28 29 7b 0d 72 | 65 67 69 73 74 65 72 20 |ate(){.r|egister |
|000013c0| 69 6e 74 20 69 3b 0d 09 | 43 6f 70 79 42 69 74 73 |int i;..|CopyBits|
|000013d0| 28 26 62 61 63 74 50 6f | 72 74 2e 70 6f 72 74 42 |(&bactPo|rt.portB|
|000013e0| 69 74 73 2c 26 74 68 65 | 50 6f 72 74 2d 3e 70 6f |its,&the|Port->po|
|000013f0| 72 74 42 69 74 73 2c 0d | 09 09 26 62 61 63 74 50 |rtBits,.|..&bactP|
|00001400| 6f 72 74 2e 70 6f 72 74 | 52 65 63 74 2c 26 74 68 |ort.port|Rect,&th|
|00001410| 65 50 6f 72 74 2d 3e 70 | 6f 72 74 52 65 63 74 2c |ePort->p|ortRect,|
|00001420| 0d 09 09 73 72 63 43 6f | 70 79 2c 6e 69 6c 29 3b |...srcCo|py,nil);|
|00001430| 0d 09 50 65 6e 53 69 7a | 65 28 33 2c 33 29 3b 0d |..PenSiz|e(3,3);.|
|00001440| 09 66 6f 72 28 69 3d 30 | 3b 69 3c 6e 75 6d 42 75 |.for(i=0|;i<numBu|
|00001450| 67 73 3b 69 2b 2b 29 7b | 0d 09 09 4d 6f 76 65 54 |gs;i++){|...MoveT|
|00001460| 6f 28 62 75 67 5b 69 5d | 2e 6c 6f 63 2e 68 2c 62 |o(bug[i]|.loc.h,b|
|00001470| 75 67 5b 69 5d 2e 6c 6f | 63 2e 76 29 3b 0d 09 09 |ug[i].lo|c.v);...|
|00001480| 4c 69 6e 65 28 30 2c 30 | 29 3b 0d 09 7d 0d 09 50 |Line(0,0|);..}..P|
|00001490| 65 6e 53 69 7a 65 28 31 | 2c 31 29 3b 0d 7d 0d 0d |enSize(1|,1);.}..|
|000014a0| 76 6f 69 64 20 57 69 6e | 64 6f 77 41 63 74 69 76 |void Win|dowActiv|
|000014b0| 61 74 65 28 61 63 74 69 | 76 65 29 0d 42 6f 6f 6c |ate(acti|ve).Bool|
|000014c0| 65 61 6e 20 61 63 74 69 | 76 65 3b 0d 7b 0d 09 69 |ean acti|ve;.{..i|
|000014d0| 66 28 61 63 74 69 76 65 | 29 7b 0d 09 09 44 69 73 |f(active|){...Dis|
|000014e0| 61 62 6c 65 49 74 65 6d | 28 47 65 74 31 52 65 73 |ableItem|(Get1Res|
|000014f0| 6f 75 72 63 65 28 27 4d | 45 4e 55 27 2c 31 33 30 |ource('M|ENU',130|
|00001500| 29 2c 30 29 3b 0d 09 09 | 45 6e 61 62 6c 65 49 74 |),0);...|EnableIt|
|00001510| 65 6d 28 47 65 74 31 52 | 65 73 6f 75 72 63 65 28 |em(Get1R|esource(|
|00001520| 27 4d 45 4e 55 27 2c 31 | 33 31 29 2c 30 29 3b 0d |'MENU',1|31),0);.|
|00001530| 09 09 44 72 61 77 4d 65 | 6e 75 42 61 72 28 29 3b |..DrawMe|nuBar();|
|00001540| 0d 09 7d 65 6c 73 65 7b | 0d 09 09 45 6e 61 62 6c |..}else{|...Enabl|
|00001550| 65 49 74 65 6d 28 47 65 | 74 31 52 65 73 6f 75 72 |eItem(Ge|t1Resour|
|00001560| 63 65 28 27 4d 45 4e 55 | 27 2c 31 33 30 29 2c 30 |ce('MENU|',130),0|
|00001570| 29 3b 0d 09 09 44 69 73 | 61 62 6c 65 49 74 65 6d |);...Dis|ableItem|
|00001580| 28 47 65 74 31 52 65 73 | 6f 75 72 63 65 28 27 4d |(Get1Res|ource('M|
|00001590| 45 4e 55 27 2c 31 33 31 | 29 2c 30 29 3b 0d 09 09 |ENU',131|),0);...|
|000015a0| 44 72 61 77 4d 65 6e 75 | 42 61 72 28 29 3b 0d 09 |DrawMenu|Bar();..|
|000015b0| 7d 0d 7d 0d 0d 76 6f 69 | 64 20 4d 61 6b 65 50 6f |}.}..voi|d MakePo|
|000015c0| 72 74 28 70 6f 72 74 29 | 0d 72 65 67 69 73 74 65 |rt(port)|.registe|
|000015d0| 72 20 47 72 61 66 50 74 | 72 20 70 6f 72 74 3b 20 |r GrafPt|r port; |
|000015e0| 2f 2a 20 70 6f 72 74 20 | 6d 75 73 74 20 62 65 20 |/* port |must be |
|000015f0| 61 20 47 72 61 66 50 74 | 72 20 74 6f 20 61 20 76 |a GrafPt|r to a v|
|00001600| 61 6c 69 64 20 70 6f 72 | 74 20 2a 2f 0d 7b 0d 52 |alid por|t */.{.R|
|00001610| 65 63 74 20 72 3b 0d 72 | 65 67 69 73 74 65 72 20 |ect r;.r|egister |
|00001620| 69 6e 74 20 72 6f 77 42 | 79 74 65 73 3b 0d 09 72 |int rowB|ytes;..r|
|00001630| 3d 74 68 65 50 6f 72 74 | 2d 3e 70 6f 72 74 52 65 |=thePort|->portRe|
|00001640| 63 74 3b 0d 09 72 6f 77 | 42 79 74 65 73 3d 28 72 |ct;..row|Bytes=(r|
|00001650| 2e 72 69 67 68 74 2d 72 | 2e 6c 65 66 74 2b 31 35 |.right-r|.left+15|
|00001660| 29 2f 31 36 2a 32 3b 0d | 09 4f 70 65 6e 50 6f 72 |)/16*2;.|.OpenPor|
|00001670| 74 28 70 6f 72 74 29 3b | 0d 09 70 6f 72 74 2d 3e |t(port);|..port->|
|00001680| 70 6f 72 74 42 69 74 73 | 2e 62 61 73 65 41 64 64 |portBits|.baseAdd|
|00001690| 72 3d 4e 65 77 50 74 72 | 28 28 6c 6f 6e 67 29 72 |r=NewPtr|((long)r|
|000016a0| 6f 77 42 79 74 65 73 2a | 28 72 2e 62 6f 74 74 6f |owBytes*|(r.botto|
|000016b0| 6d 2d 72 2e 74 6f 70 29 | 29 3b 0d 09 70 6f 72 74 |m-r.top)|);..port|
|000016c0| 2d 3e 70 6f 72 74 42 69 | 74 73 2e 72 6f 77 42 79 |->portBi|ts.rowBy|
|000016d0| 74 65 73 3d 72 6f 77 42 | 79 74 65 73 3b 0d 09 70 |tes=rowB|ytes;..p|
|000016e0| 6f 72 74 2d 3e 70 6f 72 | 74 42 69 74 73 2e 62 6f |ort->por|tBits.bo|
|000016f0| 75 6e 64 73 3d 70 6f 72 | 74 2d 3e 70 6f 72 74 52 |unds=por|t->portR|
|00001700| 65 63 74 3d 72 3b 0d 09 | 52 65 63 74 52 67 6e 28 |ect=r;..|RectRgn(|
|00001710| 70 6f 72 74 2d 3e 76 69 | 73 52 67 6e 2c 26 72 29 |port->vi|sRgn,&r)|
|00001720| 3b 0d 7d 0d 0d 2f 2a 20 | 69 6e 74 65 72 65 73 74 |;.}../* |interest|
|00001730| 69 6e 67 20 70 61 72 74 | 20 2a 2f 0d 0d 76 6f 69 |ing part| */..voi|
|00001740| 64 20 49 6e 69 74 28 29 | 0d 7b 0d 72 65 67 69 73 |d Init()|.{.regis|
|00001750| 74 65 72 20 69 6e 74 20 | 69 3b 0d 09 47 65 74 44 |ter int |i;..GetD|
|00001760| 61 74 65 54 69 6d 65 28 | 26 72 61 6e 64 53 65 65 |ateTime(|&randSee|
|00001770| 64 29 3b 0d 09 50 65 6e | 53 69 7a 65 28 33 2c 33 |d);..Pen|Size(3,3|
|00001780| 29 3b 0d 09 66 6f 72 20 | 28 69 3d 30 3b 69 3c 6e |);..for |(i=0;i<n|
|00001790| 75 6d 42 75 67 73 3b 2b | 2b 69 29 20 7b 0d 09 72 |umBugs;+|+i) {..r|
|000017a0| 65 67 69 73 74 65 72 20 | 69 6e 74 20 67 65 6e 65 |egister |int gene|
|000017b0| 3b 0d 09 69 6e 74 20 73 | 75 6d 3b 0d 09 09 62 75 |;..int s|um;...bu|
|000017c0| 67 5b 69 5d 2e 6c 6f 63 | 2e 68 3d 52 61 6e 64 6f |g[i].loc|.h=Rando|
|000017d0| 6d 52 61 6e 67 65 28 46 | 69 65 6c 64 57 69 64 74 |mRange(F|ieldWidt|
|000017e0| 68 2d 33 29 3b 0d 09 09 | 62 75 67 5b 69 5d 2e 6c |h-3);...|bug[i].l|
|000017f0| 6f 63 2e 76 3d 52 61 6e | 64 6f 6d 52 61 6e 67 65 |oc.v=Ran|domRange|
|00001800| 28 46 69 65 6c 64 48 65 | 69 67 68 74 2d 33 29 3b |(FieldHe|ight-3);|
|00001810| 0d 09 09 62 75 67 5b 69 | 5d 2e 64 69 72 3d 52 61 |...bug[i|].dir=Ra|
|00001820| 6e 64 6f 6d 52 61 6e 67 | 65 28 36 29 3b 0d 09 09 |ndomRang|e(6);...|
|00001830| 73 75 6d 3d 30 3b 0d 09 | 09 66 6f 72 28 67 65 6e |sum=0;..|.for(gen|
|00001840| 65 3d 30 3b 67 65 6e 65 | 3c 36 3b 67 65 6e 65 2b |e=0;gene|<6;gene+|
|00001850| 2b 29 20 73 75 6d 2b 3d | 20 62 75 67 5b 69 5d 2e |+) sum+=| bug[i].|
|00001860| 67 65 6e 65 5b 67 65 6e | 65 5d 3d 31 3c 3c 52 61 |gene[gen|e]=1<<Ra|
|00001870| 6e 64 6f 6d 52 61 6e 67 | 65 28 31 30 29 3b 0d 09 |ndomRang|e(10);..|
|00001880| 09 62 75 67 5b 69 5d 2e | 73 75 6d 3d 73 75 6d 3b |.bug[i].|sum=sum;|
|00001890| 0d 09 09 62 75 67 5b 69 | 5d 2e 68 65 61 6c 74 68 |...bug[i|].health|
|000018a0| 3d 49 6e 69 74 48 65 61 | 6c 74 68 3b 0d 09 7d 0d |=InitHea|lth;..}.|
|000018b0| 09 50 65 6e 53 69 7a 65 | 28 31 2c 31 29 3b 0d 09 |.PenSize|(1,1);..|
|000018c0| 47 65 74 50 6f 72 74 28 | 26 77 69 6e 64 6f 77 4d |GetPort(|&windowM|
|000018d0| 61 70 29 3b 0d 09 4d 61 | 6b 65 50 6f 72 74 28 26 |ap);..Ma|kePort(&|
|000018e0| 62 61 63 74 50 6f 72 74 | 29 3b 0d 09 45 72 61 73 |bactPort|);..Eras|
|000018f0| 65 52 65 63 74 28 26 74 | 68 65 50 6f 72 74 2d 3e |eRect(&t|hePort->|
|00001900| 70 6f 72 74 52 65 63 74 | 29 3b 0d 09 53 65 74 50 |portRect|);..SetP|
|00001910| 6f 72 74 28 77 69 6e 64 | 6f 77 4d 61 70 29 3b 0d |ort(wind|owMap);.|
|00001920| 09 66 6f 72 28 69 3d 30 | 3b 69 3c 49 6e 69 74 42 |.for(i=0|;i<InitB|
|00001930| 61 63 74 3b 69 2b 2b 29 | 20 50 75 74 42 61 63 74 |act;i++)| PutBact|
|00001940| 65 72 69 61 28 29 3b 0d | 7d 0d 0d 76 6f 69 64 20 |eria();.|}..void |
|00001950| 44 6f 47 65 6e 65 72 61 | 74 69 6f 6e 28 29 0d 7b |DoGenera|tion().{|
|00001960| 0d 72 65 67 69 73 74 65 | 72 20 42 75 67 20 2a 63 |.registe|r Bug *c|
|00001970| 75 72 42 75 67 3b 0d 09 | 4f 62 73 63 75 72 65 43 |urBug;..|ObscureC|
|00001980| 75 72 73 6f 72 28 29 3b | 0d 09 50 75 74 42 61 63 |ursor();|..PutBac|
|00001990| 74 65 72 69 61 28 29 3b | 0d 09 2f 2a 20 4d 6f 76 |teria();|../* Mov|
|000019a0| 65 20 65 76 65 72 79 62 | 6f 64 79 20 61 6e 64 20 |e everyb|ody and |
|000019b0| 61 64 61 70 74 20 6f 74 | 68 65 72 20 76 61 6c 75 |adapt ot|her valu|
|000019c0| 65 73 20 2a 2f 0d 09 50 | 65 6e 53 69 7a 65 28 33 |es */..P|enSize(3|
|000019d0| 2c 33 29 3b 0d 09 63 75 | 72 42 75 67 3d 26 62 75 |,3);..cu|rBug=&bu|
|000019e0| 67 5b 6e 75 6d 42 75 67 | 73 5d 3b 0d 09 64 6f 20 |g[numBug|s];..do |
|000019f0| 7b 0d 09 09 4d 6f 76 65 | 42 75 67 28 2d 2d 63 75 |{...Move|Bug(--cu|
|00001a00| 72 42 75 67 29 3b 0d 09 | 09 69 66 28 63 75 72 42 |rBug);..|.if(curB|
|00001a10| 75 67 2d 3e 68 65 61 6c | 74 68 20 3c 20 2d 44 69 |ug->heal|th < -Di|
|00001a20| 65 54 69 6d 65 29 4b 69 | 6c 6c 42 75 67 28 63 75 |eTime)Ki|llBug(cu|
|00001a30| 72 42 75 67 29 3b 0d 09 | 09 65 6c 73 65 20 69 66 |rBug);..|.else if|
|00001a40| 28 63 75 72 42 75 67 2d | 3e 61 67 65 2b 2b 3e 53 |(curBug-|>age++>S|
|00001a50| 70 6c 69 74 41 67 65 20 | 26 26 20 63 75 72 42 75 |plitAge |&& curBu|
|00001a60| 67 2d 3e 68 65 61 6c 74 | 68 3e 53 74 72 6f 6e 67 |g->healt|h>Strong|
|00001a70| 48 65 61 6c 74 68 29 53 | 70 6c 69 74 42 75 67 28 |Health)S|plitBug(|
|00001a80| 63 75 72 42 75 67 29 3b | 0d 09 7d 20 77 68 69 6c |curBug);|..} whil|
|00001a90| 65 20 28 63 75 72 42 75 | 67 21 3d 26 62 75 67 5b |e (curBu|g!=&bug[|
|00001aa0| 30 5d 29 3b 0d 09 50 65 | 6e 50 61 74 28 62 6c 61 |0]);..Pe|nPat(bla|
|00001ab0| 63 6b 29 3b 0d 09 50 65 | 6e 53 69 7a 65 28 31 2c |ck);..Pe|nSize(1,|
|00001ac0| 31 29 3b 0d 7d 0d 0d 76 | 6f 69 64 20 57 69 6e 64 |1);.}..v|oid Wind|
|00001ad0| 6f 77 4d 6f 75 73 65 28 | 74 68 65 50 6f 69 6e 74 |owMouse(|thePoint|
|00001ae0| 29 0d 50 6f 69 6e 74 20 | 74 68 65 50 6f 69 6e 74 |).Point |thePoint|
|00001af0| 3b 0d 7b 0d 72 65 67 69 | 73 74 65 72 20 69 6e 74 |;.{.regi|ster int|
|00001b00| 20 69 3b 0d 72 65 67 69 | 73 74 65 72 20 42 75 67 | i;.regi|ster Bug|
|00001b10| 20 2a 74 68 65 42 75 67 | 3b 0d 6c 6f 6e 67 20 6d | *theBug|;.long m|
|00001b20| 69 6e 44 69 73 74 3d 49 | 6e 69 74 4d 69 6e 44 69 |inDist=I|nitMinDi|
|00001b30| 73 74 3b 0d 09 66 6f 72 | 28 69 3d 6e 75 6d 42 75 |st;..for|(i=numBu|
|00001b40| 67 73 3b 69 2d 2d 3b 29 | 7b 0d 09 09 72 65 67 69 |gs;i--;)|{...regi|
|00001b50| 73 74 65 72 20 6c 6f 6e | 67 20 64 3b 0d 09 09 69 |ster lon|g d;...i|
|00001b60| 66 28 6d 69 6e 44 69 73 | 74 3e 20 28 64 3d 53 51 |f(minDis|t> (d=SQ|
|00001b70| 44 69 73 74 28 62 75 67 | 5b 69 5d 2e 6c 6f 63 2c |Dist(bug|[i].loc,|
|00001b80| 74 68 65 50 6f 69 6e 74 | 29 29 29 7b 0d 09 09 09 |thePoint|))){....|
|00001b90| 6d 69 6e 44 69 73 74 3d | 64 3b 0d 09 09 09 74 68 |minDist=|d;....th|
|00001ba0| 65 42 75 67 3d 26 62 75 | 67 5b 69 5d 3b 0d 09 7d |eBug=&bu|g[i];..}|
|00001bb0| 09 7d 0d 09 69 66 28 6d | 69 6e 44 69 73 74 3c 49 |.}..if(m|inDist<I|
|00001bc0| 6e 69 74 4d 69 6e 44 69 | 73 74 29 7b 0d 09 09 57 |nitMinDi|st){...W|
|00001bd0| 69 6e 64 6f 77 52 65 63 | 6f 72 64 20 73 68 6f 77 |indowRec|ord show|
|00001be0| 57 69 6e 64 6f 77 3b 0d | 09 09 52 65 63 74 20 52 |Window;.|..Rect R|
|00001bf0| 3b 0d 09 09 72 65 67 69 | 73 74 65 72 20 69 6e 74 |;...regi|ster int|
|00001c00| 20 78 3b 0d 09 09 52 2e | 6c 65 66 74 3d 35 30 3b | x;...R.|left=50;|
|00001c10| 52 2e 74 6f 70 3d 37 30 | 3b 52 2e 72 69 67 68 74 |R.top=70|;R.right|
|00001c20| 3d 32 32 35 3b 52 2e 62 | 6f 74 74 6f 6d 3d 31 36 |=225;R.b|ottom=16|
|00001c30| 30 3b 0d 09 09 69 66 28 | 74 68 65 42 75 67 2d 3e |0;...if(|theBug->|
|00001c40| 6c 6f 63 2e 68 3c 46 69 | 65 6c 64 57 69 64 74 68 |loc.h<Fi|eldWidth|
|00001c50| 2f 32 29 4f 66 66 73 65 | 74 52 65 63 74 28 26 52 |/2)Offse|tRect(&R|
|00001c60| 2c 46 69 65 6c 64 57 69 | 64 74 68 2f 32 2c 30 29 |,FieldWi|dth/2,0)|
|00001c70| 3b 0d 09 09 4e 65 77 57 | 69 6e 64 6f 77 28 26 73 |;...NewW|indow(&s|
|00001c80| 68 6f 77 57 69 6e 64 6f | 77 2c 26 52 2c 22 5c 70 |howWindo|w,&R,"\p|
|00001c90| 22 2c 74 72 75 65 2c 32 | 2c 46 72 6f 6e 74 4d 6f |",true,2|,FrontMo|
|00001ca0| 73 74 2c 66 61 6c 73 65 | 2c 30 29 3b 0d 09 09 53 |st,false|,0);...S|
|00001cb0| 65 74 50 6f 72 74 28 26 | 73 68 6f 77 57 69 6e 64 |etPort(&|showWind|
|00001cc0| 6f 77 29 3b 0d 09 09 54 | 65 78 74 46 6f 6e 74 28 |ow);...T|extFont(|
|00001cd0| 73 79 73 74 65 6d 46 6f | 6e 74 29 3b 0d 09 09 4d |systemFo|nt);...M|
|00001ce0| 6f 76 65 54 6f 28 31 30 | 2c 32 30 29 3b 0d 09 09 |oveTo(10|,20);...|
|00001cf0| 44 72 61 77 53 74 72 69 | 6e 67 28 22 5c 70 42 75 |DrawStri|ng("\pBu|
|00001d00| 67 20 22 29 3b 0d 09 09 | 78 3d 74 68 65 42 75 67 |g ");...|x=theBug|
|00001d10| 2d 26 62 75 67 5b 30 5d | 2b 31 3b 0d 23 64 65 66 |-&bug[0]|+1;.#def|
|00001d20| 69 6e 65 20 44 72 61 77 | 44 69 67 69 74 28 64 29 |ine Draw|Digit(d)|
|00001d30| 20 44 72 61 77 43 68 61 | 72 28 27 30 27 2b 28 64 | DrawCha|r('0'+(d|
|00001d40| 29 29 0d 09 09 69 66 28 | 78 3e 3d 31 30 30 29 44 |))...if(|x>=100)D|
|00001d50| 72 61 77 44 69 67 69 74 | 28 78 2f 31 30 30 29 3b |rawDigit|(x/100);|
|00001d60| 0d 09 09 69 66 28 78 3e | 3d 31 30 29 44 72 61 77 |...if(x>|=10)Draw|
|00001d70| 44 69 67 69 74 28 78 2f | 31 30 25 31 30 29 3b 0d |Digit(x/|10%10);.|
|00001d80| 09 09 44 72 61 77 44 69 | 67 69 74 28 78 25 31 30 |..DrawDi|git(x%10|
|00001d90| 29 3b 0d 09 09 44 72 61 | 77 53 74 72 69 6e 67 28 |);...Dra|wString(|
|00001da0| 22 5c 70 20 6f 66 20 22 | 29 3b 0d 09 09 78 3d 6e |"\p of "|);...x=n|
|00001db0| 75 6d 42 75 67 73 3b 0d | 09 09 69 66 28 78 3e 3d |umBugs;.|..if(x>=|
|00001dc0| 31 30 30 29 44 72 61 77 | 44 69 67 69 74 28 78 2f |100)Draw|Digit(x/|
|00001dd0| 31 30 30 29 3b 0d 09 09 | 69 66 28 78 3e 3d 31 30 |100);...|if(x>=10|
|00001de0| 29 44 72 61 77 44 69 67 | 69 74 28 78 2f 31 30 25 |)DrawDig|it(x/10%|
|00001df0| 31 30 29 3b 0d 09 09 44 | 72 61 77 44 69 67 69 74 |10);...D|rawDigit|
|00001e00| 28 78 25 31 30 29 3b 0d | 23 75 6e 64 65 66 20 44 |(x%10);.|#undef D|
|00001e10| 72 61 77 44 69 67 69 74 | 0d 09 09 54 65 78 74 46 |rawDigit|...TextF|
|00001e20| 6f 6e 74 28 67 65 6e 65 | 76 61 29 3b 0d 09 09 4d |ont(gene|va);...M|
|00001e30| 6f 76 65 54 6f 28 31 30 | 2c 33 36 29 3b 0d 09 09 |oveTo(10|,36);...|
|00001e40| 44 72 61 77 53 74 72 69 | 6e 67 28 22 5c 70 41 67 |DrawStri|ng("\pAg|
|00001e50| 65 22 29 3b 0d 09 09 52 | 2e 6c 65 66 74 3d 36 30 |e");...R|.left=60|
|00001e60| 3b 52 2e 74 6f 70 3d 32 | 38 3b 52 2e 72 69 67 68 |;R.top=2|8;R.righ|
|00001e70| 74 3d 31 36 30 3b 52 2e | 62 6f 74 74 6f 6d 3d 33 |t=160;R.|bottom=3|
|00001e80| 36 3b 0d 09 09 46 72 61 | 6d 65 52 65 63 74 28 26 |6;...Fra|meRect(&|
|00001e90| 52 29 3b 0d 09 09 49 6e | 73 65 74 52 65 63 74 28 |R);...In|setRect(|
|00001ea0| 26 52 2c 31 2c 31 29 3b | 0d 09 09 52 2e 72 69 67 |&R,1,1);|...R.rig|
|00001eb0| 68 74 3d 52 2e 6c 65 66 | 74 2b 53 63 61 6c 65 28 |ht=R.lef|t+Scale(|
|00001ec0| 38 30 2c 4d 61 78 41 67 | 65 2c 74 68 65 42 75 67 |80,MaxAg|e,theBug|
|00001ed0| 2d 3e 61 67 65 29 3b 0d | 09 09 69 66 28 52 2e 72 |->age);.|..if(R.r|
|00001ee0| 69 67 68 74 3e 3d 31 36 | 30 29 7b 0d 09 09 09 52 |ight>=16|0){....R|
|00001ef0| 2e 72 69 67 68 74 3d 31 | 36 30 3b 0d 09 09 09 4d |.right=1|60;....M|
|00001f00| 6f 76 65 54 6f 28 31 36 | 32 2c 33 32 29 3b 0d 09 |oveTo(16|2,32);..|
|00001f10| 09 09 4c 69 6e 65 28 35 | 2c 30 29 3b 0d 09 09 09 |..Line(5|,0);....|
|00001f20| 4c 69 6e 65 28 2d 32 2c | 2d 32 29 3b 0d 09 09 09 |Line(-2,|-2);....|
|00001f30| 4d 6f 76 65 28 32 2c 32 | 29 3b 0d 09 09 09 4c 69 |Move(2,2|);....Li|
|00001f40| 6e 65 28 2d 32 2c 32 29 | 3b 0d 09 09 7d 0d 09 09 |ne(-2,2)|;...}...|
|00001f50| 46 69 6c 6c 52 65 63 74 | 28 26 52 2c 67 72 61 79 |FillRect|(&R,gray|
|00001f60| 29 3b 0d 09 09 4d 6f 76 | 65 54 6f 28 36 30 2c 32 |);...Mov|eTo(60,2|
|00001f70| 38 29 3b 0d 09 09 4c 69 | 6e 65 28 30 2c 31 30 29 |8);...Li|ne(0,10)|
|00001f80| 3b 0d 09 09 4d 6f 76 65 | 54 6f 28 36 30 2b 53 63 |;...Move|To(60+Sc|
|00001f90| 61 6c 65 28 31 30 30 2c | 4d 61 78 41 67 65 2c 53 |ale(100,|MaxAge,S|
|00001fa0| 70 6c 69 74 41 67 65 29 | 2c 32 38 29 3b 0d 09 09 |plitAge)|,28);...|
|00001fb0| 4c 69 6e 65 28 30 2c 31 | 30 29 3b 0d 09 09 4d 6f |Line(0,1|0);...Mo|
|00001fc0| 76 65 54 6f 28 31 30 2c | 35 32 29 3b 0d 09 09 44 |veTo(10,|52);...D|
|00001fd0| 72 61 77 53 74 72 69 6e | 67 28 22 5c 70 48 65 61 |rawStrin|g("\pHea|
|00001fe0| 6c 74 68 22 29 3b 0d 09 | 09 52 2e 6c 65 66 74 3d |lth");..|.R.left=|
|00001ff0| 36 30 3b 52 2e 74 6f 70 | 3d 34 34 3b 52 2e 72 69 |60;R.top|=44;R.ri|
|00002000| 67 68 74 3d 31 36 30 3b | 52 2e 62 6f 74 74 6f 6d |ght=160;|R.bottom|
|00002010| 3d 35 32 3b 0d 09 09 46 | 72 61 6d 65 52 65 63 74 |=52;...F|rameRect|
|00002020| 28 26 52 29 3b 0d 09 09 | 49 6e 73 65 74 52 65 63 |(&R);...|InsetRec|
|00002030| 74 28 26 52 2c 31 2c 31 | 29 3b 0d 09 09 52 2e 72 |t(&R,1,1|);...R.r|
|00002040| 69 67 68 74 3d 52 2e 6c | 65 66 74 2b 53 63 61 6c |ight=R.l|eft+Scal|
|00002050| 65 28 39 38 2c 4d 61 78 | 48 65 61 6c 74 68 2c 74 |e(98,Max|Health,t|
|00002060| 68 65 42 75 67 2d 3e 68 | 65 61 6c 74 68 29 3b 0d |heBug->h|ealth);.|
|00002070| 09 09 46 69 6c 6c 52 65 | 63 74 28 26 52 2c 67 72 |..FillRe|ct(&R,gr|
|00002080| 61 79 29 3b 0d 09 09 4d | 6f 76 65 54 6f 28 36 30 |ay);...M|oveTo(60|
|00002090| 2c 34 34 29 3b 0d 09 09 | 4c 69 6e 65 28 30 2c 31 |,44);...|Line(0,1|
|000020a0| 30 29 3b 0d 09 09 4d 6f | 76 65 54 6f 28 36 30 2b |0);...Mo|veTo(60+|
|000020b0| 53 63 61 6c 65 28 31 30 | 30 2c 4d 61 78 48 65 61 |Scale(10|0,MaxHea|
|000020c0| 6c 74 68 2c 53 74 72 6f | 6e 67 48 65 61 6c 74 68 |lth,Stro|ngHealth|
|000020d0| 29 2c 34 34 29 3b 0d 09 | 09 4c 69 6e 65 28 30 2c |),44);..|.Line(0,|
|000020e0| 31 30 29 3b 0d 09 09 4d | 6f 76 65 54 6f 28 31 35 |10);...M|oveTo(15|
|000020f0| 39 2c 34 34 29 3b 0d 09 | 09 4c 69 6e 65 28 30 2c |9,44);..|.Line(0,|
|00002100| 31 30 29 3b 0d 09 09 4d | 6f 76 65 54 6f 28 31 30 |10);...M|oveTo(10|
|00002110| 2c 36 39 29 3b 0d 09 09 | 44 72 61 77 53 74 72 69 |,69);...|DrawStri|
|00002120| 6e 67 28 22 5c 70 47 65 | 6e 65 73 22 29 3b 0d 09 |ng("\pGe|nes");..|
|00002130| 09 50 65 6e 53 69 7a 65 | 28 32 2c 31 29 3b 0d 09 |.PenSize|(2,1);..|
|00002140| 09 66 6f 72 28 78 3d 30 | 3b 78 3c 36 3b 78 2b 2b |.for(x=0|;x<6;x++|
|00002150| 29 7b 0d 09 09 09 4d 6f | 76 65 54 6f 28 37 32 2b |){....Mo|veTo(72+|
|00002160| 31 35 2a 78 2c 36 38 29 | 3b 0d 09 09 09 73 77 69 |15*x,68)|;....swi|
|00002170| 74 63 68 28 74 68 65 42 | 75 67 2d 3e 67 65 6e 65 |tch(theB|ug->gene|
|00002180| 5b 28 78 2b 48 4c 29 25 | 36 5d 29 7b 0d 09 09 09 |[(x+HL)%|6]){....|
|00002190| 63 61 73 65 20 31 3c 3c | 30 3a 4c 69 6e 65 28 30 |case 1<<|0:Line(0|
|000021a0| 2c 2d 31 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-1); br|eak;....|
|000021b0| 63 61 73 65 20 31 3c 3c | 31 3a 4c 69 6e 65 28 30 |case 1<<|1:Line(0|
|000021c0| 2c 2d 32 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-2); br|eak;....|
|000021d0| 63 61 73 65 20 31 3c 3c | 32 3a 4c 69 6e 65 28 30 |case 1<<|2:Line(0|
|000021e0| 2c 2d 33 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-3); br|eak;....|
|000021f0| 63 61 73 65 20 31 3c 3c | 33 3a 4c 69 6e 65 28 30 |case 1<<|3:Line(0|
|00002200| 2c 2d 34 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-4); br|eak;....|
|00002210| 63 61 73 65 20 31 3c 3c | 34 3a 4c 69 6e 65 28 30 |case 1<<|4:Line(0|
|00002220| 2c 2d 35 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-5); br|eak;....|
|00002230| 63 61 73 65 20 31 3c 3c | 35 3a 4c 69 6e 65 28 30 |case 1<<|5:Line(0|
|00002240| 2c 2d 36 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-6); br|eak;....|
|00002250| 63 61 73 65 20 31 3c 3c | 36 3a 4c 69 6e 65 28 30 |case 1<<|6:Line(0|
|00002260| 2c 2d 37 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-7); br|eak;....|
|00002270| 63 61 73 65 20 31 3c 3c | 37 3a 4c 69 6e 65 28 30 |case 1<<|7:Line(0|
|00002280| 2c 2d 38 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-8); br|eak;....|
|00002290| 63 61 73 65 20 31 3c 3c | 38 3a 4c 69 6e 65 28 30 |case 1<<|8:Line(0|
|000022a0| 2c 2d 39 29 3b 20 62 72 | 65 61 6b 3b 0d 09 09 09 |,-9); br|eak;....|
|000022b0| 63 61 73 65 20 31 3c 3c | 39 3a 4c 69 6e 65 28 30 |case 1<<|9:Line(0|
|000022c0| 2c 2d 31 30 29 3b 20 62 | 72 65 61 6b 3b 0d 09 09 |,-10); b|reak;...|
|000022d0| 09 63 61 73 65 20 31 3c | 3c 31 30 3a 4c 69 6e 65 |.case 1<|<10:Line|
|000022e0| 28 30 2c 2d 31 31 29 3b | 20 62 72 65 61 6b 3b 0d |(0,-11);| break;.|
|000022f0| 09 09 09 7d 0d 09 09 7d | 0d 09 09 50 65 6e 53 69 |...}...}|...PenSi|
|00002300| 7a 65 28 31 2c 31 29 3b | 0d 09 09 54 65 78 74 53 |ze(1,1);|...TextS|
|00002310| 69 7a 65 28 39 29 3b 0d | 09 09 4d 6f 76 65 54 6f |ize(9);.|..MoveTo|
|00002320| 28 36 38 2c 37 37 29 3b | 44 72 61 77 53 74 72 69 |(68,77);|DrawStri|
|00002330| 6e 67 28 22 5c 70 48 4c | 22 29 3b 0d 09 09 4d 6f |ng("\pHL|");...Mo|
|00002340| 76 65 54 6f 28 38 36 2c | 37 37 29 3b 44 72 61 77 |veTo(86,|77);Draw|
|00002350| 53 74 72 69 6e 67 28 22 | 5c 70 4c 22 29 3b 0d 09 |String("|\pL");..|
|00002360| 09 4d 6f 76 65 54 6f 28 | 31 30 31 2c 37 37 29 3b |.MoveTo(|101,77);|
|00002370| 44 72 61 77 53 74 72 69 | 6e 67 28 22 5c 70 46 22 |DrawStri|ng("\pF"|
|00002380| 29 3b 0d 09 09 4d 6f 76 | 65 54 6f 28 31 31 36 2c |);...Mov|eTo(116,|
|00002390| 37 37 29 3b 44 72 61 77 | 53 74 72 69 6e 67 28 22 |77);Draw|String("|
|000023a0| 5c 70 52 22 29 3b 0d 09 | 09 4d 6f 76 65 54 6f 28 |\pR");..|.MoveTo(|
|000023b0| 31 32 38 2c 37 37 29 3b | 44 72 61 77 53 74 72 69 |128,77);|DrawStri|
|000023c0| 6e 67 28 22 5c 70 48 52 | 22 29 3b 0d 09 09 4d 6f |ng("\pHR|");...Mo|
|000023d0| 76 65 54 6f 28 31 34 33 | 2c 37 37 29 3b 44 72 61 |veTo(143|,77);Dra|
|000023e0| 77 53 74 72 69 6e 67 28 | 22 5c 70 52 56 22 29 3b |wString(|"\pRV");|
|000023f0| 0d 09 09 53 65 74 50 6f | 72 74 28 77 69 6e 64 6f |...SetPo|rt(windo|
|00002400| 77 4d 61 70 29 3b 0d 09 | 09 50 65 6e 53 69 7a 65 |wMap);..|.PenSize|
|00002410| 28 33 2c 33 29 3b 0d 09 | 09 4d 6f 76 65 54 6f 28 |(3,3);..|.MoveTo(|
|00002420| 74 68 65 42 75 67 2d 3e | 6c 6f 63 2e 68 2c 74 68 |theBug->|loc.h,th|
|00002430| 65 42 75 67 2d 3e 6c 6f | 63 2e 76 29 3b 0d 09 09 |eBug->lo|c.v);...|
|00002440| 77 68 69 6c 65 28 53 74 | 69 6c 6c 44 6f 77 6e 28 |while(St|illDown(|
|00002450| 29 29 7b 0d 09 09 09 6c | 6f 6e 67 20 2a 6a 75 6e |)){....l|ong *jun|
|00002460| 6b 3b 0d 09 09 09 50 65 | 6e 50 61 74 28 77 68 69 |k;....Pe|nPat(whi|
|00002470| 74 65 29 3b 0d 09 09 09 | 4c 69 6e 65 28 30 2c 30 |te);....|Line(0,0|
|00002480| 29 3b 0d 09 09 09 44 65 | 6c 61 79 28 31 30 2c 26 |);....De|lay(10,&|
|00002490| 6a 75 6e 6b 29 3b 0d 09 | 09 09 50 65 6e 50 61 74 |junk);..|..PenPat|
|000024a0| 28 62 6c 61 63 6b 29 3b | 0d 09 09 09 4c 69 6e 65 |(black);|....Line|
|000024b0| 28 30 2c 30 29 3b 0d 09 | 09 09 44 65 6c 61 79 28 |(0,0);..|..Delay(|
|000024c0| 31 30 2c 26 6a 75 6e 6b | 29 3b 0d 09 09 09 7d 0d |10,&junk|);....}.|
|000024d0| 09 09 43 6c 6f 73 65 57 | 69 6e 64 6f 77 28 26 73 |..CloseW|indow(&s|
|000024e0| 68 6f 77 57 69 6e 64 6f | 77 29 3b 0d 09 09 50 65 |howWindo|w);...Pe|
|000024f0| 6e 53 69 7a 65 28 31 2c | 31 29 3b 0d 09 7d 20 65 |nSize(1,|1);..} e|
|00002500| 6c 73 65 20 53 79 73 42 | 65 65 70 28 35 29 3b 09 |lse SysB|eep(5);.|
|00002510| 2f 2a 20 6e 6f 20 62 75 | 67 20 69 73 20 63 6c 6f |/* no bu|g is clo|
|00002520| 73 65 20 65 6e 6f 75 67 | 68 20 2a 2f 0d 7d 0d 0d |se enoug|h */.}..|
|00002530| 76 6f 69 64 20 50 75 74 | 42 61 63 74 65 72 69 61 |void Put|Bacteria|
|00002540| 28 29 7b 0d 72 65 67 69 | 73 74 65 72 20 69 6e 74 |(){.regi|ster int|
|00002550| 20 68 2c 76 3b 0d 09 2f | 2a 20 4d 61 6b 65 20 61 | h,v;../|* Make a|
|00002560| 20 62 61 63 74 65 72 69 | 61 20 66 6f 72 20 66 6f | bacteri|a for fo|
|00002570| 6f 64 20 2a 2f 0d 09 73 | 77 69 74 63 68 28 67 72 |od */..s|witch(gr|
|00002580| 6f 77 4d 6f 64 65 29 7b | 0d 09 63 61 73 65 20 67 |owMode){|..case g|
|00002590| 72 6f 77 47 61 72 64 65 | 6e 3a 0d 09 09 69 66 28 |rowGarde|n:...if(|
|000025a0| 52 61 6e 64 6f 6d 52 61 | 6e 67 65 28 32 29 29 7b |RandomRa|nge(2)){|
|000025b0| 0d 09 09 09 68 3d 52 61 | 6e 64 6f 6d 52 61 6e 67 |....h=Ra|ndomRang|
|000025c0| 65 28 35 30 29 2b 28 46 | 69 65 6c 64 57 69 64 74 |e(50)+(F|ieldWidt|
|000025d0| 68 2d 35 30 29 2f 32 3b | 0d 09 09 09 76 3d 52 61 |h-50)/2;|....v=Ra|
|000025e0| 6e 64 6f 6d 52 61 6e 67 | 65 28 35 30 29 2b 28 46 |ndomRang|e(50)+(F|
|000025f0| 69 65 6c 64 48 65 69 67 | 68 74 2d 35 30 29 2f 32 |ieldHeig|ht-50)/2|
|00002600| 3b 0d 09 09 09 62 72 65 | 61 6b 3b 0d 09 09 7d 0d |;....bre|ak;...}.|
|00002610| 09 63 61 73 65 20 67 72 | 6f 77 55 6e 69 66 6f 72 |.case gr|owUnifor|
|00002620| 6d 3a 0d 09 09 68 3d 52 | 61 6e 64 6f 6d 52 61 6e |m:...h=R|andomRan|
|00002630| 67 65 28 46 69 65 6c 64 | 57 69 64 74 68 2d 31 30 |ge(Field|Width-10|
|00002640| 29 2b 35 3b 0d 09 09 76 | 3d 52 61 6e 64 6f 6d 52 |)+5;...v|=RandomR|
|00002650| 61 6e 67 65 28 46 69 65 | 6c 64 48 65 69 67 68 74 |ange(Fie|ldHeight|
|00002660| 2d 31 30 29 2b 35 3b 0d | 09 09 62 72 65 61 6b 3b |-10)+5;.|..break;|
|00002670| 0d 09 63 61 73 65 20 67 | 72 6f 77 4e 6f 6e 65 3a |..case g|rowNone:|
|00002680| 0d 09 09 72 65 74 75 72 | 6e 3b 0d 09 63 61 73 65 |...retur|n;..case|
|00002690| 20 67 72 6f 77 50 61 74 | 74 65 72 6e 3a 0d 09 09 | growPat|tern:...|
|000026a0| 68 3d 62 61 63 74 4c 6f | 63 2e 68 3b 0d 09 09 69 |h=bactLo|c.h;...i|
|000026b0| 66 28 20 28 68 2b 3d 33 | 30 37 29 20 3e 46 69 65 |f( (h+=3|07) >Fie|
|000026c0| 6c 64 57 69 64 74 68 2d | 35 29 20 68 2d 3d 46 69 |ldWidth-|5) h-=Fi|
|000026d0| 65 6c 64 57 69 64 74 68 | 2d 31 30 3b 0d 09 09 62 |eldWidth|-10;...b|
|000026e0| 61 63 74 4c 6f 63 2e 68 | 3d 68 3b 0d 09 09 76 3d |actLoc.h|=h;...v=|
|000026f0| 62 61 63 74 4c 6f 63 2e | 76 3b 0d 09 09 69 66 28 |bactLoc.|v;...if(|
|00002700| 20 28 76 2b 3d 31 31 33 | 29 20 3e 46 69 65 6c 64 | (v+=113|) >Field|
|00002710| 48 65 69 67 68 74 2d 35 | 29 20 76 2d 3d 46 69 65 |Height-5|) v-=Fie|
|00002720| 6c 64 48 65 69 67 68 74 | 2d 31 30 3b 0d 09 09 62 |ldHeight|-10;...b|
|00002730| 61 63 74 4c 6f 63 2e 76 | 3d 76 3b 0d 09 09 62 72 |actLoc.v|=v;...br|
|00002740| 65 61 6b 3b 0d 09 63 61 | 73 65 20 09 67 72 6f 77 |eak;..ca|se .grow|
|00002750| 43 65 6e 74 65 72 65 64 | 3a 0d 09 09 68 3d 52 61 |Centered|:...h=Ra|
|00002760| 6e 64 6f 6d 52 61 6e 67 | 65 28 28 46 69 65 6c 64 |ndomRang|e((Field|
|00002770| 57 69 64 74 68 2d 31 30 | 29 2f 32 29 2b 52 61 6e |Width-10|)/2)+Ran|
|00002780| 64 6f 6d 52 61 6e 67 65 | 28 28 46 69 65 6c 64 57 |domRange|((FieldW|
|00002790| 69 64 74 68 2d 31 30 29 | 2f 32 29 2b 31 30 3b 0d |idth-10)|/2)+10;.|
|000027a0| 09 09 76 3d 52 61 6e 64 | 6f 6d 52 61 6e 67 65 28 |..v=Rand|omRange(|
|000027b0| 28 46 69 65 6c 64 48 65 | 69 67 68 74 2d 31 30 29 |(FieldHe|ight-10)|
|000027c0| 2f 32 29 2b 52 61 6e 64 | 6f 6d 52 61 6e 67 65 28 |/2)+Rand|omRange(|
|000027d0| 28 46 69 65 6c 64 48 65 | 69 67 68 74 2d 31 30 29 |(FieldHe|ight-10)|
|000027e0| 2f 32 29 2b 31 30 3b 0d | 09 09 62 72 65 61 6b 3b |/2)+10;.|..break;|
|000027f0| 0d 09 7d 0d 09 61 73 6d | 7b 09 09 2f 2a 20 73 65 |..}..asm|{../* se|
|00002800| 74 20 74 68 65 20 62 69 | 74 20 69 6e 20 6f 75 72 |t the bi|t in our|
|00002810| 20 62 69 74 6d 61 70 2c | 20 74 68 65 20 71 75 69 | bitmap,| the qui|
|00002820| 63 6b 20 61 6e 64 20 64 | 69 72 74 79 20 77 61 79 |ck and d|irty way|
|00002830| 20 2a 2f 0d 09 09 6d 6f | 76 65 2e 77 09 76 2c 44 | */...mo|ve.w.v,D|
|00002840| 30 0d 09 3b 09 73 75 62 | 2e 77 09 62 61 63 74 50 |0..;.sub|.w.bactP|
|00002850| 6f 72 74 2e 70 6f 72 74 | 42 69 74 73 2e 62 6f 75 |ort.port|Bits.bou|
|00002860| 6e 64 73 2e 74 6f 70 2c | 44 30 09 3b 74 68 69 73 |nds.top,|D0.;this|
|00002870| 20 6e 75 6d 62 65 72 20 | 69 73 20 7a 65 72 6f 20 | number |is zero |
|00002880| 68 65 72 65 0d 09 09 6d | 75 6c 75 09 09 62 61 63 |here...m|ulu..bac|
|00002890| 74 50 6f 72 74 2e 70 6f | 72 74 42 69 74 73 2e 72 |tPort.po|rtBits.r|
|000028a0| 6f 77 42 79 74 65 73 2c | 44 30 0d 09 09 6d 6f 76 |owBytes,|D0...mov|
|000028b0| 65 61 2e 6c 09 62 61 63 | 74 50 6f 72 74 2e 70 6f |ea.l.bac|tPort.po|
|000028c0| 72 74 42 69 74 73 2e 62 | 61 73 65 41 64 64 72 2c |rtBits.b|aseAddr,|
|000028d0| 41 30 0d 09 09 61 64 64 | 61 2e 6c 09 44 30 2c 41 |A0...add|a.l.D0,A|
|000028e0| 30 0d 09 09 6d 6f 76 65 | 2e 77 09 68 2c 44 31 0d |0...move|.w.h,D1.|
|000028f0| 09 3b 09 73 75 62 2e 77 | 09 62 61 63 74 50 6f 72 |.;.sub.w|.bactPor|
|00002900| 74 2e 70 6f 72 74 42 69 | 74 73 2e 62 6f 75 6e 64 |t.portBi|ts.bound|
|00002910| 73 2e 6c 65 66 74 2c 44 | 31 09 3b 74 68 69 73 20 |s.left,D|1.;this |
|00002920| 6e 75 6d 62 65 72 20 69 | 73 20 7a 65 72 6f 20 68 |number i|s zero h|
|00002930| 65 72 65 0d 09 09 6d 6f | 76 65 2e 77 09 44 31 2c |ere...mo|ve.w.D1,|
|00002940| 44 30 0d 09 09 6e 6f 74 | 2e 77 09 44 30 0d 09 09 |D0...not|.w.D0...|
|00002950| 6c 73 72 2e 77 09 23 33 | 2c 44 31 0d 09 09 62 73 |lsr.w.#3|,D1...bs|
|00002960| 65 74 09 09 44 30 2c 30 | 28 41 30 2c 44 31 2e 77 |et..D0,0|(A0,D1.w|
|00002970| 29 0d 09 7d 0d 09 2f 2a | 20 64 72 61 77 20 74 68 |)..}../*| draw th|
|00002980| 65 20 62 69 74 20 6f 6e | 20 73 63 72 65 65 6e 20 |e bit on| screen |
|00002990| 2a 2f 0d 09 4d 6f 76 65 | 54 6f 28 68 2c 76 29 3b |*/..Move|To(h,v);|
|000029a0| 0d 09 4c 69 6e 65 28 30 | 2c 30 29 3b 0d 7d 0d 0d |..Line(0|,0);.}..|
|000029b0| 76 6f 69 64 20 4d 6f 76 | 65 42 75 67 28 74 68 65 |void Mov|eBug(the|
|000029c0| 42 75 67 29 20 2f 2a 20 | 61 73 73 75 6d 65 20 77 |Bug) /* |assume w|
|000029d0| 69 6e 64 6f 77 20 61 63 | 74 69 76 65 2c 20 50 65 |indow ac|tive, Pe|
|000029e0| 6e 53 69 7a 65 20 3d 20 | 33 2c 33 20 2a 2f 0d 72 |nSize = |3,3 */.r|
|000029f0| 65 67 69 73 74 65 72 20 | 42 75 67 20 2a 74 68 65 |egister |Bug *the|
|00002a00| 42 75 67 3b 0d 7b 0d 72 | 65 67 69 73 74 65 72 20 |Bug;.{.r|egister |
|00002a10| 69 6e 74 20 72 2c 64 69 | 72 3b 0d 72 65 67 69 73 |int r,di|r;.regis|
|00002a20| 74 65 72 20 69 6e 74 20 | 68 2c 76 3b 0d 09 2f 2a |ter int |h,v;../*|
|00002a30| 20 72 65 6d 6f 76 65 20 | 62 75 67 20 66 72 6f 6d | remove |bug from|
|00002a40| 20 6f 6c 64 20 6c 6f 63 | 61 74 69 6f 6e 20 2a 2f | old loc|ation */|
|00002a50| 0d 09 50 65 6e 50 61 74 | 28 77 68 69 74 65 29 3b |..PenPat|(white);|
|00002a60| 0d 09 4d 6f 76 65 54 6f | 28 20 68 3d 74 68 65 42 |..MoveTo|( h=theB|
|00002a70| 75 67 2d 3e 6c 6f 63 2e | 68 20 2c 20 76 3d 74 68 |ug->loc.|h , v=th|
|00002a80| 65 42 75 67 2d 3e 6c 6f | 63 2e 76 20 29 3b 0d 09 |eBug->lo|c.v );..|
|00002a90| 4c 69 6e 65 28 30 2c 30 | 29 3b 0d 09 2f 2a 20 63 |Line(0,0|);../* c|
|00002aa0| 6f 6d 70 75 74 65 20 6e | 65 77 20 6c 6f 63 61 74 |ompute n|ew locat|
|00002ab0| 69 6f 6e 20 2a 2f 0d 09 | 69 66 28 74 68 65 42 75 |ion */..|if(theBu|
|00002ac0| 67 2d 3e 68 65 61 6c 74 | 68 3e 3d 30 29 20 7b 0d |g->healt|h>=0) {.|
|00002ad0| 09 09 7b 09 2f 2a 20 63 | 6f 6d 70 75 74 65 20 64 |..{./* c|ompute d|
|00002ae0| 69 72 65 63 74 69 6f 6e | 20 2a 2f 0d 09 09 72 65 |irection| */...re|
|00002af0| 67 69 73 74 65 72 20 69 | 6e 74 20 2a 67 65 6e 65 |gister i|nt *gene|
|00002b00| 3b 0d 09 09 09 64 69 72 | 3d 74 68 65 42 75 67 2d |;....dir|=theBug-|
|00002b10| 3e 64 69 72 3b 0d 09 09 | 09 72 3d 52 61 6e 64 6f |>dir;...|.r=Rando|
|00002b20| 6d 52 61 6e 67 65 28 74 | 68 65 42 75 67 2d 3e 73 |mRange(t|heBug->s|
|00002b30| 75 6d 29 3b 0d 09 09 09 | 66 6f 72 28 67 65 6e 65 |um);....|for(gene|
|00002b40| 3d 26 74 68 65 42 75 67 | 2d 3e 67 65 6e 65 5b 36 |=&theBug|->gene[6|
|00002b50| 5d 3b 2d 2d 67 65 6e 65 | 21 3d 26 74 68 65 42 75 |];--gene|!=&theBu|
|00002b60| 67 2d 3e 67 65 6e 65 5b | 30 5d 3b 29 0d 09 09 09 |g->gene[|0];)....|
|00002b70| 09 69 66 28 20 28 72 2d | 3d 2a 67 65 6e 65 29 20 |.if( (r-|=*gene) |
|00002b80| 3c 30 29 64 69 72 2b 2b | 3b 0d 09 09 09 69 66 28 |<0)dir++|;....if(|
|00002b90| 64 69 72 3e 3d 36 29 64 | 69 72 2d 3d 36 3b 0d 09 |dir>=6)d|ir-=6;..|
|00002ba0| 09 7d 0d 09 09 74 68 65 | 42 75 67 2d 3e 64 69 72 |.}...the|Bug->dir|
|00002bb0| 3d 64 69 72 3b 0d 09 09 | 2f 2a 20 6d 6f 76 65 20 |=dir;...|/* move |
|00002bc0| 69 6e 20 6e 65 77 20 64 | 69 72 65 63 74 69 6f 6e |in new d|irection|
|00002bd0| 20 2a 2f 0d 09 09 69 66 | 28 20 28 68 2b 3d 68 6d | */...if|( (h+=hm|
|00002be0| 6f 76 65 5b 64 69 72 5d | 29 20 3c 30 29 68 2b 3d |ove[dir]|) <0)h+=|
|00002bf0| 46 69 65 6c 64 57 69 64 | 74 68 2d 32 3b 0d 09 09 |FieldWid|th-2;...|
|00002c00| 65 6c 73 65 20 69 66 28 | 68 3e 46 69 65 6c 64 57 |else if(|h>FieldW|
|00002c10| 69 64 74 68 2d 33 29 68 | 2d 3d 46 69 65 6c 64 57 |idth-3)h|-=FieldW|
|00002c20| 69 64 74 68 2d 32 3b 0d | 09 09 69 66 28 20 28 76 |idth-2;.|..if( (v|
|00002c30| 2b 3d 76 6d 6f 76 65 5b | 64 69 72 5d 29 20 3c 30 |+=vmove[|dir]) <0|
|00002c40| 29 76 2b 3d 46 69 65 6c | 64 48 65 69 67 68 74 2d |)v+=Fiel|dHeight-|
|00002c50| 32 3b 0d 09 09 65 6c 73 | 65 20 69 66 28 76 3e 46 |2;...els|e if(v>F|
|00002c60| 69 65 6c 64 48 65 69 67 | 68 74 2d 33 29 76 2d 3d |ieldHeig|ht-3)v-=|
|00002c70| 46 69 65 6c 64 48 65 69 | 67 68 74 2d 32 3b 0d 09 |FieldHei|ght-2;..|
|00002c80| 7d 0d 09 53 65 74 50 6f | 72 74 28 26 62 61 63 74 |}..SetPo|rt(&bact|
|00002c90| 50 6f 72 74 29 3b 0d 09 | 2f 2a 20 65 61 74 20 62 |Port);..|/* eat b|
|00002ca0| 61 63 74 65 72 69 61 2c | 20 61 64 61 70 74 20 68 |acteria,| adapt h|
|00002cb0| 65 61 6c 74 68 20 2a 2f | 0d 2f 2a 09 69 66 28 43 |ealth */|./*.if(C|
|00002cc0| 6f 75 6e 74 50 69 78 65 | 6c 73 28 68 2c 76 29 21 |ountPixe|ls(h,v)!|
|00002cd0| 3d 47 65 74 50 69 78 65 | 6c 28 68 2c 76 29 2b 47 |=GetPixe|l(h,v)+G|
|00002ce0| 65 74 50 69 78 65 6c 28 | 68 2b 31 2c 76 29 2b 47 |etPixel(|h+1,v)+G|
|00002cf0| 65 74 50 69 78 65 6c 28 | 68 2b 32 2c 76 29 2b 0d |etPixel(|h+2,v)+.|
|00002d00| 09 09 47 65 74 50 69 78 | 65 6c 28 68 2c 76 2b 31 |..GetPix|el(h,v+1|
|00002d10| 29 2b 47 65 74 50 69 78 | 65 6c 28 68 2b 31 2c 76 |)+GetPix|el(h+1,v|
|00002d20| 2b 31 29 2b 47 65 74 50 | 69 78 65 6c 28 68 2b 32 |+1)+GetP|ixel(h+2|
|00002d30| 2c 76 2b 31 29 2b 0d 09 | 09 47 65 74 50 69 78 65 |,v+1)+..|.GetPixe|
|00002d40| 6c 28 68 2c 76 2b 32 29 | 2b 47 65 74 50 69 78 65 |l(h,v+2)|+GetPixe|
|00002d50| 6c 28 68 2b 31 2c 76 2b | 32 29 2b 47 65 74 50 69 |l(h+1,v+|2)+GetPi|
|00002d60| 78 65 6c 28 68 2b 32 2c | 76 2b 32 29 29 7b 0d 09 |xel(h+2,|v+2)){..|
|00002d70| 09 53 79 73 42 65 65 70 | 28 31 29 3b 53 79 73 42 |.SysBeep|(1);SysB|
|00002d80| 65 65 70 28 31 29 3b 53 | 79 73 42 65 65 70 28 31 |eep(1);S|ysBeep(1|
|00002d90| 29 3b 44 65 62 75 67 67 | 65 72 28 29 3b 7d 2a 2f |);Debugg|er();}*/|
|00002da0| 0d 09 72 3d 43 6f 75 6e | 74 50 69 78 65 6c 73 28 |..r=Coun|tPixels(|
|00002db0| 68 2c 76 29 2a 48 65 61 | 6c 74 68 50 65 72 42 61 |h,v)*Hea|lthPerBa|
|00002dc0| 63 74 2b 74 68 65 42 75 | 67 2d 3e 68 65 61 6c 74 |ct+theBu|g->healt|
|00002dd0| 68 2d 31 3b 0d 09 69 66 | 28 72 3e 4d 61 78 48 65 |h-1;..if|(r>MaxHe|
|00002de0| 61 6c 74 68 29 72 3d 4d | 61 78 48 65 61 6c 74 68 |alth)r=M|axHealth|
|00002df0| 3b 0d 09 53 65 74 50 6f | 72 74 28 77 69 6e 64 6f |;..SetPo|rt(windo|
|00002e00| 77 4d 61 70 29 3b 0d 09 | 69 66 28 72 3e 30 20 7c |wMap);..|if(r>0 ||
|00002e10| 7c 20 28 72 3e 3d 2d 44 | 69 65 54 69 6d 65 20 26 || (r>=-D|ieTime &|
|00002e20| 26 20 72 25 32 3d 3d 30 | 29 20 29 7b 0d 09 09 2f |& r%2==0|) ){.../|
|00002e30| 2a 20 64 72 61 77 20 62 | 75 67 20 61 74 20 6e 65 |* draw b|ug at ne|
|00002e40| 77 20 6c 6f 63 61 74 69 | 6f 6e 20 2a 2f 0d 09 09 |w locati|on */...|
|00002e50| 50 65 6e 50 61 74 28 62 | 6c 61 63 6b 29 3b 0d 09 |PenPat(b|lack);..|
|00002e60| 09 4d 6f 76 65 54 6f 28 | 20 74 68 65 42 75 67 2d |.MoveTo(| theBug-|
|00002e70| 3e 6c 6f 63 2e 68 3d 68 | 20 2c 20 74 68 65 42 75 |>loc.h=h| , theBu|
|00002e80| 67 2d 3e 6c 6f 63 2e 76 | 3d 76 20 29 3b 0d 09 09 |g->loc.v|=v );...|
|00002e90| 4c 69 6e 65 28 30 2c 30 | 29 3b 0d 09 7d 0d 09 74 |Line(0,0|);..}..t|
|00002ea0| 68 65 42 75 67 2d 3e 68 | 65 61 6c 74 68 3d 72 3b |heBug->h|ealth=r;|
|00002eb0| 0d 7d 0d 0d 76 6f 69 64 | 20 4b 69 6c 6c 42 75 67 |.}..void| KillBug|
|00002ec0| 28 74 68 65 42 75 67 29 | 0d 42 75 67 20 2a 74 68 |(theBug)|.Bug *th|
|00002ed0| 65 42 75 67 3b 0d 7b 0d | 09 2a 74 68 65 42 75 67 |eBug;.{.|.*theBug|
|00002ee0| 3d 62 75 67 5b 2d 2d 6e | 75 6d 42 75 67 73 5d 3b |=bug[--n|umBugs];|
|00002ef0| 0d 7d 0d 0d 76 6f 69 64 | 20 53 70 6c 69 74 42 75 |.}..void| SplitBu|
|00002f00| 67 28 74 68 65 42 75 67 | 29 0d 42 75 67 20 2a 74 |g(theBug|).Bug *t|
|00002f10| 68 65 42 75 67 3b 0d 7b | 0d 72 65 67 69 73 74 65 |heBug;.{|.registe|
|00002f20| 72 20 69 6e 74 20 69 2c | 72 2c 67 2c 73 75 6d 3b |r int i,|r,g,sum;|
|00002f30| 0d 09 69 66 28 6e 75 6d | 42 75 67 73 3c 4d 61 78 |..if(num|Bugs<Max|
|00002f40| 42 75 67 73 29 7b 0d 09 | 09 62 75 67 5b 6e 75 6d |Bugs){..|.bug[num|
|00002f50| 42 75 67 73 2b 2b 5d 3d | 2a 74 68 65 42 75 67 3b |Bugs++]=|*theBug;|
|00002f60| 0d 09 09 72 3d 52 61 6e | 64 6f 6d 52 61 6e 67 65 |...r=Ran|domRange|
|00002f70| 28 36 29 3b 0d 09 09 67 | 3d 74 68 65 42 75 67 2d |(6);...g|=theBug-|
|00002f80| 3e 67 65 6e 65 5b 72 5d | 3b 0d 09 09 67 2a 3d 32 |>gene[r]|;...g*=2|
|00002f90| 3b 0d 09 09 74 68 65 42 | 75 67 2d 3e 67 65 6e 65 |;...theB|ug->gene|
|00002fa0| 5b 72 5d 3d 67 3b 0d 09 | 09 69 66 28 67 3e 31 30 |[r]=g;..|.if(g>10|
|00002fb0| 32 34 29 0d 09 09 09 66 | 6f 72 28 69 3d 46 3b 69 |24)....f|or(i=F;i|
|00002fc0| 3c 3d 4c 3b 69 2b 2b 29 | 0d 09 09 09 09 74 68 65 |<=L;i++)|.....the|
|00002fd0| 42 75 67 2d 3e 67 65 6e | 65 5b 69 5d 2f 3d 32 3b |Bug->gen|e[i]/=2;|
|00002fe0| 0d 09 09 74 68 65 42 75 | 67 2d 3e 68 65 61 6c 74 |...theBu|g->healt|
|00002ff0| 68 2f 3d 32 3b 0d 09 09 | 74 68 65 42 75 67 2d 3e |h/=2;...|theBug->|
|00003000| 61 67 65 3d 30 3b 0d 09 | 09 73 75 6d 3d 30 3b 0d |age=0;..|.sum=0;.|
|00003010| 09 09 66 6f 72 28 69 3d | 46 3b 69 3c 3d 4c 3b 69 |..for(i=|F;i<=L;i|
|00003020| 2b 2b 29 0d 09 09 09 73 | 75 6d 2b 3d 74 68 65 42 |++)....s|um+=theB|
|00003030| 75 67 2d 3e 67 65 6e 65 | 5b 69 5d 3b 0d 09 09 74 |ug->gene|[i];...t|
|00003040| 68 65 42 75 67 2d 3e 73 | 75 6d 3d 73 75 6d 3b 0d |heBug->s|um=sum;.|
|00003050| 09 09 72 3d 52 61 6e 64 | 6f 6d 52 61 6e 67 65 28 |..r=Rand|omRange(|
|00003060| 36 29 3b 0d 09 09 67 3d | 28 74 68 65 42 75 67 3d |6);...g=|(theBug=|
|00003070| 26 62 75 67 5b 6e 75 6d | 42 75 67 73 2d 31 5d 29 |&bug[num|Bugs-1])|
|00003080| 2d 3e 67 65 6e 65 5b 72 | 5d 3b 0d 09 09 67 2f 3d |->gene[r|];...g/=|
|00003090| 32 3b 0d 09 09 74 68 65 | 42 75 67 2d 3e 67 65 6e |2;...the|Bug->gen|
|000030a0| 65 5b 72 5d 3d 67 3b 0d | 09 09 74 68 65 42 75 67 |e[r]=g;.|..theBug|
|000030b0| 2d 3e 68 65 61 6c 74 68 | 2f 3d 32 3b 0d 09 09 74 |->health|/=2;...t|
|000030c0| 68 65 42 75 67 2d 3e 61 | 67 65 3d 30 3b 0d 09 09 |heBug->a|ge=0;...|
|000030d0| 73 75 6d 3d 30 3b 0d 09 | 09 66 6f 72 28 69 3d 46 |sum=0;..|.for(i=F|
|000030e0| 3b 69 3c 3d 4c 3b 69 2b | 2b 29 73 75 6d 2b 3d 74 |;i<=L;i+|+)sum+=t|
|000030f0| 68 65 42 75 67 2d 3e 67 | 65 6e 65 5b 69 5d 3b 0d |heBug->g|ene[i];.|
|00003100| 09 09 74 68 65 42 75 67 | 2d 3e 73 75 6d 3d 73 75 |..theBug|->sum=su|
|00003110| 6d 3b 0d 09 7d 20 65 6c | 73 65 20 53 79 73 42 65 |m;..} el|se SysBe|
|00003120| 65 70 28 32 30 29 3b 0d | 7d 0d 0d 75 6e 73 69 67 |ep(20);.|}..unsig|
|00003130| 6e 65 64 20 69 6e 74 20 | 52 61 6e 64 6f 6d 52 61 |ned int |RandomRa|
|00003140| 6e 67 65 28 2f 2a 20 75 | 6e 73 69 67 6e 65 64 20 |nge(/* u|nsigned |
|00003150| 69 6e 74 20 74 6f 70 20 | 2a 2f 29 0d 2f 2a 20 50 |int top |*/)./* P|
|00003160| 72 6f 64 75 63 65 73 20 | 72 61 6e 64 6f 6d 20 6e |roduces |random n|
|00003170| 75 6d 62 65 72 20 30 2e | 2e 74 6f 70 2d 31 20 2a |umber 0.|.top-1 *|
|00003180| 2f 0d 7b 09 61 73 6d 7b | 0d 09 09 63 6c 72 2e 77 |/.{.asm{|...clr.w|
|00003190| 09 2d 28 53 50 29 0d 09 | 09 5f 52 61 6e 64 6f 6d |.-(SP)..|._Random|
|000031a0| 0d 09 09 6d 6f 76 65 2e | 77 09 28 53 50 29 2b 2c |...move.|w.(SP)+,|
|000031b0| 44 30 0d 09 09 6d 75 6c | 75 09 09 34 28 53 50 29 |D0...mul|u..4(SP)|
|000031c0| 2c 44 30 0d 09 09 73 77 | 61 70 09 09 44 30 0d 7d |,D0...sw|ap..D0.}|
|000031d0| 09 09 7d 0d 0d 6c 6f 6e | 67 20 69 6e 74 20 53 51 |..}..lon|g int SQ|
|000031e0| 44 69 73 74 28 2f 2a 20 | 50 6f 69 6e 74 20 61 2c |Dist(/* |Point a,|
|000031f0| 62 20 2a 2f 29 0d 2f 2a | 20 73 71 75 61 72 65 20 |b */)./*| square |
|00003200| 6f 66 20 64 69 73 74 61 | 6e 63 65 2e 20 20 49 73 |of dista|nce. Is|
|00003210| 20 61 77 66 75 6c 20 74 | 6f 20 77 72 69 74 65 20 | awful t|o write |
|00003220| 69 6e 20 43 20 28 74 61 | 6b 65 73 20 36 37 20 69 |in C (ta|kes 67 i|
|00003230| 6e 73 74 65 61 64 20 6f | 66 20 38 20 69 6e 73 74 |nstead o|f 8 inst|
|00003240| 72 75 63 74 69 6f 6e 73 | 21 29 20 2a 2f 0d 7b 09 |ructions|!) */.{.|
|00003250| 61 73 6d 7b 0d 09 09 6d | 6f 76 65 2e 77 09 34 28 |asm{...m|ove.w.4(|
|00003260| 53 50 29 2c 44 30 09 09 | 3b 62 2e 76 0d 09 09 73 |SP),D0..|;b.v...s|
|00003270| 75 62 2e 77 09 38 28 53 | 50 29 2c 44 30 09 09 3b |ub.w.8(S|P),D0..;|
|00003280| 61 2e 76 0d 09 09 6d 75 | 6c 73 09 09 44 30 2c 44 |a.v...mu|ls..D0,D|
|00003290| 30 0d 09 09 6d 6f 76 65 | 2e 77 09 36 28 53 50 29 |0...move|.w.6(SP)|
|000032a0| 2c 44 31 09 09 3b 62 2e | 68 0d 09 09 73 75 62 2e |,D1..;b.|h...sub.|
|000032b0| 77 09 31 30 28 53 50 29 | 2c 44 31 09 3b 61 2e 68 |w.10(SP)|,D1.;a.h|
|000032c0| 0d 09 09 6d 75 6c 73 09 | 09 44 31 2c 44 31 0d 09 |...muls.|.D1,D1..|
|000032d0| 09 61 64 64 2e 6c 09 09 | 44 31 2c 44 30 0d 7d 09 |.add.l..|D1,D0.}.|
|000032e0| 7d 0d 0d 69 6e 74 20 53 | 63 61 6c 65 28 61 2c 20 |}..int S|cale(a, |
|000032f0| 62 2c 20 63 29 0d 69 6e | 74 20 61 2c 20 62 2c 20 |b, c).in|t a, b, |
|00003300| 63 3b 0d 7b 09 2f 2a 20 | 74 68 69 73 20 72 6f 75 |c;.{./* |this rou|
|00003310| 74 69 6e 65 20 63 6f 6d | 70 75 74 65 73 20 74 68 |tine com|putes th|
|00003320| 65 20 72 6f 75 6e 64 65 | 64 20 76 61 6c 75 65 20 |e rounde|d value |
|00003330| 6f 66 20 28 63 2a 28 61 | 2f 62 29 29 2e 0d 09 54 |of (c*(a|/b))...T|
|00003340| 68 69 73 20 69 73 20 64 | 6f 6e 65 20 61 73 20 28 |his is d|one as (|
|00003350| 63 2a 61 2b 62 2f 32 29 | 2f 62 2c 20 77 68 65 72 |c*a+b/2)|/b, wher|
|00003360| 65 20 69 6e 74 65 72 6d | 65 64 69 61 74 65 20 72 |e interm|ediate r|
|00003370| 65 73 75 6c 74 73 20 61 | 72 65 20 6c 6f 6e 67 2e |esults a|re long.|
|00003380| 20 2a 2f 0d 09 61 73 6d | 7b 0d 09 09 6d 6f 76 65 | */..asm|{...move|
|00003390| 2e 77 09 61 2c 44 30 09 | 09 3b 67 65 74 20 61 0d |.w.a,D0.|.;get a.|
|000033a0| 09 09 6d 75 6c 73 09 09 | 63 2c 44 30 09 09 3b 61 |..muls..|c,D0..;a|
|000033b0| 2a 63 0d 09 09 6d 6f 76 | 65 2e 77 09 62 2c 44 31 |*c...mov|e.w.b,D1|
|000033c0| 09 09 3b 67 65 74 20 62 | 0d 09 09 65 78 74 2e 6c |..;get b|...ext.l|
|000033d0| 09 09 44 31 0d 09 09 64 | 69 76 73 09 09 23 32 2c |..D1...d|ivs..#2,|
|000033e0| 44 31 09 3b 62 2f 32 0d | 09 09 65 78 74 2e 6c 09 |D1.;b/2.|..ext.l.|
|000033f0| 09 44 31 0d 09 09 61 64 | 64 2e 6c 09 09 44 31 2c |.D1...ad|d.l..D1,|
|00003400| 44 30 09 3b 63 2a 61 2b | 62 2f 32 0d 09 09 64 69 |D0.;c*a+|b/2...di|
|00003410| 76 73 09 09 62 2c 44 30 | 09 09 3b 72 65 73 75 6c |vs..b,D0|..;resul|
|00003420| 74 0d 7d 09 7d 0d 0d 69 | 6e 74 20 43 6f 75 6e 74 |t.}.}..i|nt Count|
|00003430| 50 69 78 65 6c 73 28 68 | 2c 76 29 0d 72 65 67 69 |Pixels(h|,v).regi|
|00003440| 73 74 65 72 20 69 6e 74 | 20 68 3b 0d 69 6e 74 20 |ster int| h;.int |
|00003450| 76 3b 0d 7b 09 72 65 67 | 69 73 74 65 72 20 62 69 |v;.{.reg|ister bi|
|00003460| 74 3b 0d 09 2f 2a 20 63 | 6f 75 6e 74 20 74 68 65 |t;../* c|ount the|
|00003470| 20 6e 75 6d 62 65 72 20 | 6f 66 20 70 69 78 65 6c | number |of pixel|
|00003480| 73 20 74 68 61 74 20 77 | 6f 75 6c 64 20 66 61 6c |s that w|ould fal|
|00003490| 6c 20 75 6e 64 65 72 20 | 61 20 33 2a 33 20 70 65 |l under |a 3*3 pe|
|000034a0| 6e 20 61 74 20 6c 6f 63 | 61 74 69 6f 6e 20 68 2c |n at loc|ation h,|
|000034b0| 76 20 2a 2f 0d 09 2f 2a | 20 61 6c 73 6f 20 63 6c |v */../*| also cl|
|000034c0| 65 61 72 20 74 68 65 20 | 70 69 78 65 6c 73 20 2a |ear the |pixels *|
|000034d0| 2f 0d 09 61 73 6d 7b 0d | 09 09 6d 6f 76 65 61 2e |/..asm{.|..movea.|
|000034e0| 6c 09 74 68 65 50 6f 72 | 74 2c 41 30 0d 09 09 6d |l.thePor|t,A0...m|
|000034f0| 6f 76 65 2e 77 09 76 2c | 44 30 0d 3b 09 63 6f 6d |ove.w.v,|D0.;.com|
|00003500| 70 65 6e 73 61 74 69 6f | 6e 20 66 6f 72 20 6f 72 |pensatio|n for or|
|00003510| 69 67 69 6e 20 69 73 20 | 6e 6f 74 20 6e 65 63 63 |igin is |not necc|
|00003520| 65 73 61 72 79 20 68 65 | 72 65 0d 3b 09 09 73 75 |esary he|re.;..su|
|00003530| 62 2e 77 09 4f 46 46 53 | 45 54 28 47 72 61 66 50 |b.w.OFFS|ET(GrafP|
|00003540| 6f 72 74 2c 70 6f 72 74 | 42 69 74 73 2e 62 6f 75 |ort,port|Bits.bou|
|00003550| 6e 64 73 2e 74 6f 70 29 | 20 28 41 30 29 2c 44 30 |nds.top)| (A0),D0|
|00003560| 0d 3b 09 09 73 75 62 2e | 77 09 4f 46 46 53 45 54 |.;..sub.|w.OFFSET|
|00003570| 28 47 72 61 66 50 6f 72 | 74 2c 70 6f 72 74 42 69 |(GrafPor|t,portBi|
|00003580| 74 73 2e 62 6f 75 6e 64 | 73 2e 6c 65 66 74 29 2c |ts.bound|s.left),|
|00003590| 62 69 74 0d 09 09 6d 75 | 6c 75 09 09 4f 46 46 53 |bit...mu|lu..OFFS|
|000035a0| 45 54 28 47 72 61 66 50 | 6f 72 74 2c 70 6f 72 74 |ET(GrafP|ort,port|
|000035b0| 42 69 74 73 2e 72 6f 77 | 42 79 74 65 73 29 20 28 |Bits.row|Bytes) (|
|000035c0| 41 30 29 2c 44 30 0d 09 | 09 6d 6f 76 65 61 2e 6c |A0),D0..|.movea.l|
|000035d0| 09 4f 46 46 53 45 54 28 | 47 72 61 66 50 6f 72 74 |.OFFSET(|GrafPort|
|000035e0| 2c 70 6f 72 74 42 69 74 | 73 2e 62 61 73 65 41 64 |,portBit|s.baseAd|
|000035f0| 64 72 29 20 28 41 30 29 | 2c 41 31 0d 09 09 61 64 |dr) (A0)|,A1...ad|
|00003600| 64 61 2e 6c 09 44 30 2c | 41 31 09 3b 61 64 64 72 |da.l.D0,|A1.;addr|
|00003610| 65 73 73 20 6f 66 20 74 | 68 65 20 74 6f 70 20 72 |ess of t|he top r|
|00003620| 6f 77 0d 09 09 63 6c 72 | 2e 77 09 44 30 09 09 3b |ow...clr|.w.D0..;|
|00003630| 66 6f 72 20 73 75 6d 6d | 69 6e 67 20 75 70 20 74 |for summ|ing up t|
|00003640| 68 65 20 72 65 73 75 6c | 74 0d 09 09 6d 6f 76 65 |he resul|t...move|
|00003650| 2e 77 09 23 33 2d 31 2c | 44 32 09 3b 74 68 72 65 |.w.#3-1,|D2.;thre|
|00003660| 65 20 72 6f 77 73 2c 20 | 79 6f 75 20 6b 6e 6f 77 |e rows, |you know|
|00003670| 3f 0d 0d 09 40 30 09 6d | 6f 76 65 2e 77 09 68 2c |?...@0.m|ove.w.h,|
|00003680| 62 69 74 0d 09 09 6e 6f | 74 2e 77 09 62 69 74 09 |bit...no|t.w.bit.|
|00003690| 09 3b 6c 6f 77 65 72 20 | 74 68 72 65 65 20 62 69 |.;lower |three bi|
|000036a0| 74 73 20 61 72 65 20 62 | 69 74 20 23 0d 09 09 6d |ts are b|it #...m|
|000036b0| 6f 76 65 2e 77 09 68 2c | 44 31 0d 09 09 6c 73 72 |ove.w.h,|D1...lsr|
|000036c0| 2e 77 09 23 33 2c 44 31 | 09 3b 6f 66 66 73 65 74 |.w.#3,D1|.;offset|
|000036d0| 20 66 6f 72 20 62 79 74 | 65 20 69 6e 20 72 6f 77 | for byt|e in row|
|000036e0| 0d 09 09 62 74 73 74 09 | 09 62 69 74 2c 30 28 41 |...btst.|.bit,0(A|
|000036f0| 31 2c 44 31 2e 77 29 09 | 09 3b 74 65 73 74 20 68 |1,D1.w).|.;test h|
|00003700| 2c 76 0d 09 09 62 65 71 | 2e 73 09 09 40 31 0d 09 |,v...beq|.s..@1..|
|00003710| 09 61 64 64 2e 77 09 23 | 31 2c 44 30 0d 09 09 62 |.add.w.#|1,D0...b|
|00003720| 63 6c 72 09 09 62 69 74 | 2c 30 28 41 31 2c 44 31 |clr..bit|,0(A1,D1|
|00003730| 2e 77 29 09 09 3b 72 65 | 73 65 74 20 74 68 65 20 |.w)..;re|set the |
|00003740| 62 69 74 0d 09 40 31 09 | 73 75 62 2e 77 09 23 31 |bit..@1.|sub.w.#1|
|00003750| 2c 62 69 74 09 3b 68 2b | 31 0d 09 09 6d 6f 76 65 |,bit.;h+|1...move|
|00003760| 2e 77 09 68 2c 44 31 0d | 09 09 61 64 64 2e 77 09 |.w.h,D1.|..add.w.|
|00003770| 23 31 2c 44 31 0d 09 09 | 6c 73 72 2e 77 09 23 33 |#1,D1...|lsr.w.#3|
|00003780| 2c 44 31 09 3b 6f 66 66 | 73 65 74 20 66 6f 72 20 |,D1.;off|set for |
|00003790| 62 79 74 65 20 69 6e 20 | 72 6f 77 0d 09 09 62 74 |byte in |row...bt|
|000037a0| 73 74 09 09 62 69 74 2c | 30 28 41 31 2c 44 31 2e |st..bit,|0(A1,D1.|
|000037b0| 77 29 09 09 3b 74 65 73 | 74 20 68 2b 31 2c 76 0d |w)..;tes|t h+1,v.|
|000037c0| 09 09 62 65 71 2e 73 09 | 09 40 32 0d 09 09 61 64 |..beq.s.|.@2...ad|
|000037d0| 64 2e 77 09 23 31 2c 44 | 30 0d 09 09 62 63 6c 72 |d.w.#1,D|0...bclr|
|000037e0| 09 09 62 69 74 2c 30 28 | 41 31 2c 44 31 2e 77 29 |..bit,0(|A1,D1.w)|
|000037f0| 09 09 3b 72 65 73 65 74 | 20 74 68 65 20 62 69 74 |..;reset| the bit|
|00003800| 0d 09 40 32 09 73 75 62 | 2e 77 09 23 31 2c 62 69 |..@2.sub|.w.#1,bi|
|00003810| 74 09 3b 68 2b 32 0d 09 | 09 6d 6f 76 65 2e 77 09 |t.;h+2..|.move.w.|
|00003820| 68 2c 44 31 0d 09 09 61 | 64 64 2e 77 09 23 32 2c |h,D1...a|dd.w.#2,|
|00003830| 44 31 0d 09 09 6c 73 72 | 2e 77 09 23 33 2c 44 31 |D1...lsr|.w.#3,D1|
|00003840| 09 3b 6f 66 66 73 65 74 | 20 66 6f 72 20 62 79 74 |.;offset| for byt|
|00003850| 65 20 69 6e 20 72 6f 77 | 0d 09 09 62 74 73 74 09 |e in row|...btst.|
|00003860| 09 62 69 74 2c 30 28 41 | 31 2c 44 31 2e 77 29 09 |.bit,0(A|1,D1.w).|
|00003870| 09 3b 74 65 73 74 20 68 | 2b 32 2c 76 0d 09 09 62 |.;test h|+2,v...b|
|00003880| 65 71 2e 73 09 09 40 33 | 0d 09 09 61 64 64 2e 77 |eq.s..@3|...add.w|
|00003890| 09 23 31 2c 44 30 0d 09 | 09 62 63 6c 72 09 09 62 |.#1,D0..|.bclr..b|
|000038a0| 69 74 2c 30 28 41 31 2c | 44 31 2e 77 29 09 09 3b |it,0(A1,|D1.w)..;|
|000038b0| 72 65 73 65 74 20 74 68 | 65 20 62 69 74 0d 09 40 |reset th|e bit..@|
|000038c0| 33 09 6d 6f 76 65 2e 77 | 09 4f 46 46 53 45 54 28 |3.move.w|.OFFSET(|
|000038d0| 47 72 61 66 50 6f 72 74 | 2c 70 6f 72 74 42 69 74 |GrafPort|,portBit|
|000038e0| 73 2e 72 6f 77 42 79 74 | 65 73 29 20 28 41 30 29 |s.rowByt|es) (A0)|
|000038f0| 2c 62 69 74 0d 09 09 65 | 78 74 2e 6c 09 09 62 69 |,bit...e|xt.l..bi|
|00003900| 74 0d 09 09 61 64 64 61 | 2e 6c 09 62 69 74 2c 41 |t...adda|.l.bit,A|
|00003910| 31 09 3b 62 69 74 3d 74 | 68 65 50 6f 72 74 2d 3e |1.;bit=t|hePort->|
|00003920| 70 6f 72 74 42 69 74 73 | 2e 72 6f 77 42 79 74 65 |portBits|.rowByte|
|00003930| 73 20 68 65 72 65 0d 0d | 09 09 64 62 72 61 09 09 |s here..|..dbra..|
|00003940| 64 32 2c 40 30 0d 09 09 | 3b 72 65 61 64 79 21 0d |d2,@0...|;ready!.|
|00003950| 7d 09 7d 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |}.}.....|........|
|00003960| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00003970| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00003980| 00 00 01 00 00 00 01 16 | 00 00 00 16 00 00 00 46 |........|.......F|
|00003990| 40 90 6c 00 08 3c 00 20 | 54 ce ec 00 04 d1 c7 30 |@.l..<. |T......0|
|000039a0| 06 e6 48 d0 c0 70 07 cc | 40 90 46 01 10 56 c0 4c |..H..p..|@.F..V.L|
|000039b0| 0a 53 69 6d 75 6c 61 74 | 65 2e 63 01 02 00 00 00 |.Simulat|e.c.....|
|000039c0| 50 61 72 74 53 49 54 78 | 00 00 00 00 00 00 00 00 |PartSITx|........|
|000039d0| 00 00 50 61 72 74 53 49 | 54 78 00 00 00 00 00 00 |..PartSI|Tx......|
|000039e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000039f0| 00 00 a9 80 16 6b 00 00 | 00 00 00 00 01 5c 2c 00 |.....k..|.....\,.|
|00003a00| 00 d0 7b 00 06 4e fb 00 | 02 00 12 00 0c 00 0a 00 |..{..N..|........|
|00003a10| 12 00 06 00 22 00 02 4e | ed 04 2a 76 00 74 0b 60 |...."..N|..*v.t.`|
|00003a20| 20 26 2c 00 0a 67 f0 4e | ad 09 1a 74 05 12 00 6a | &,..g.N|...t...j|
|00003a30| 10 74 09 60 0c 76 00 74 | 05 72 06 b2 2c 00 06 66 |.t.`.v.t|.r..,..f|
|00003a40| d6 2b 43 ff f6 2b 6c 00 | 02 ff fa 1b 42 ff f4 1b |.+C..+l.|....B...|
|00003a50| 41 ff f5 06 ad 00 00 00 | 1c f9 f4 30 1e 4e f6 00 |A.......|...0.N..|
|00003a60| fe 0c 2d 00 0b ff f4 66 | 10 70 07 20 6d ff fa b0 |..-....f|.p. m...|
|00003a70| c8 67 02 70 08 1b 40 ff | f4 30 1e 4e f6 00 fe 0c |.g.p..@.|.0.N....|
|00003a80| 00 00 00 04 00 06 00 04 | 00 00 00 0a 00 09 06 47 |........|.......G|
|00003a90| 65 6e 65 76 61 09 00 00 | 01 00 00 00 01 16 00 00 |eneva...|........|
|00003aa0| 00 16 00 00 00 46 00 05 | 98 b4 04 0c 00 00 00 1c |.....F..|........|
|00003ab0| 00 46 00 01 45 54 41 42 | 00 00 00 12 45 46 4e 54 |.F..ETAB|....EFNT|
|00003ac0| 00 00 00 1e 03 ec ff ff | 00 00 00 00 00 05 98 4c |........|.......L|
|00003ad0| 03 eb ff ff 00 00 00 08 | 00 05 97 fc 00 00 00 00 |........|........|
|00003ae0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00003af0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+